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Advanced Multilingual Computer Systems for Measurement Automation and Computer- 
Aided Engineering Applications, by John L Bid well and David W. Palermo Two new, 

powerful desktop computers provide faster performance, a choice of programming languages, 

graphics, and internal mass storage for computer-aided engineering. 

Hardware Design for an Integrated Instrumentation Computer System, by Don D. 

Stewart, Robert J Homing, Ken L Burgess, Ronald G. Rogers, and James W. McLucas 
This desktop computer design is centered around a fast 16-bit microprocessor and integrated CRT 
display and flexible disc storage units, 

I/O Philosophy and Architecture for Instrument Control, by Loyd F. Nelson A nonstruc- 
tared approach provides a new series of I/O cards that have improved performance at a 
lower cost. 

Low-Cost Printers for the 9826 A and 9836 A Computers, by Michael J. Sproviero These 
thermal printers provide quality hard copy of text and graphics for HP's newest desktop 
computers, 

The 9826A/9836A Language Systems, Kathryn Y. Kwinn, Robert M. Hallissy, and Roger E. 
ison BASIC, HPL t and a powerful version of Pascal can all be used by a single 9826 A or 
9836 A Computer System. 

Data Communications for the 9826A and 9836 A Computer Systems, by Carl M. 
Dierschow and Robert P. Uhlrich The serial data communications interface handles many 
asynchronous protocols and drives a variety of RS-232-C peripherals. 

In this Issue: 

The HP desktop computer on the cover of this issue is showing you its engineering graphics 
capability by displaying a diagram of a system that its owner might be designing, or that it 
might be controlling, The computer. Model 9836A. and its smaller-screen, singfe-flexible- 
disc-drlve cousin, Model 9826 A, are the subjects of this issue, These two new desktop 
computers are state-of-the-art descendants of the HP 9825 Computer/Controller, which has 
been HP's top system controlier since 1976. Over 28,000 customers now own 9825s. 
People like desktop computers because they 1 re friendly and dedicated, and these two new 
•^^^^"^^^~ ones are no excepti ons . But we ve learned a lot since 1 976, Usi ng the latest technology, these 
new computers are up to five times faster than the 9825. They can speak three programming languages— HPL f 
BASIC, and Pascal — instead of just HPL. And they have much larger memories — up to two million bytes, or 
characters. They're also reliable, having been designed that way and strife-tested to assure a low failure rate. 

Both of these powerful machines make excellent controllers for automatic measurement, test, and control 
systems. The 9836A, with its larger screen, is especially good for computer-aided engineering, which means 
helping engineers design and develop new products or systems. The computer can do simulation, prototype 
testing, production of engineering drawings and printed circuit board layouts, software development, and report 
generation. 

An unusual feature of the new computers is the knob, a rotary control on the keyboard. When editing 
programs, the user can spin the knob to move the machine's attention rapidly to the item of interest. In 
computer-aided engineering the knob can be used to change a parameter or component value while the 
computer simulates how the product s operation will change as a result. In system control the knob can be used 
for many things, such as varying the speed of a motor 

The article on page 3 will introduce you to the 9826A and 9836A Computers. Articles about their hardware and 
software designs, how they interface with peripheral devices and instruments, and how they can communicate 
with other computers are on pages 7, 1 7, 24, and 33. A new thermal printer family designed to work with them is 
described on page 22. 
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Advanced Multilingual Computer Systems 
for Measurement Automation and 
Computer-Aided Engineering Applications 

Developing and running a test, measurement and control, 
or computer-aided engineering system is much easier if you 
have the right tooL These computer systems are designed 
specifically for such use, 



by John L Bidwell and David W. Palermo 



DESKTOP COMPUTERS have provided scientists, 
engineers, and other noncomputer professionals 
with the ability to solve computation and instru- 
ment control problems in a timely and relatively painless 
way. The new HP Model 9826A and 9836A Computer Sys- 
tems (Fig. 1) are fourth-generation desktop computers that 
blend traditional desktop computer friendliness, powerful 
computer features, and a state~of-the-art microprocessor 



with a choice of three programming languages. All of these 
ingredients take the best of the evolution of desktop com- 
puters and add the price/performance advantages of the 
latest technology. 

The 98 26 A has a 178-mm-diagonal CRT (cathode ray 
tube) d isplay and a built-in 5,25-in, 264K-by te flexible disc 
drive. The 9836A has a 310-mm-diagonal CRT display and 
two built-in 5.25-in, 264K-byte flexible disc drives. At the 




Fig. 1, The HP Model 9828 A Computer System (left) is a multilingual high- performance instru- 
ment controller with built-in display and mass storage capability The HP Model 9836 A Computer 
System (nght) is a large- screen-display version of the 9826 A with added internal mass storage 
capability it supports the same languages as the 9826 A and is designed for applications 
requiring additional graphics and computer-aided design features. 
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9826A versus 9836A 



Ttie9826A is designed to be the premier control lerol the 1980s, 
replacing [he 9825. the pas! standard of performance in instru- 
ment control, The 9826A is rackabfe and/or stackable, designed 
to be visually compatible with other HP rack-mount instruments, 
and has a high degree of internal peripheral integration within a 
package that is only 18 cm high. The built-in HP-tB interface, 
dock, knob, and graphics are all capabi lines needed by most 
instrument conlrol systems 

The 9836A is a large-screen version of the 9826A with two 
internal flexible disc drives. Computer-aided engineering is the 
target market for this new machine although it is equally capable 
as an instrument controller The powerful architecture of the 
9826A also serves the 983SA while the larger screen and second 
disc drive facilitate programming, graphics display and mass 
storage operations involving more than one medium The differ 
ences between I he 9826 A and the 9836A are limited to careful 
changes in the display and mass storage subsystems. AN of the 
other hardware and software features are the same for borh sys- 
tems. 

In adding a second disc drive to the 9836A the primary goal 
was to maintain high-speed access, especially in ihe case of 
disc-to-disc transfers. Two design paths were possible, The exist- 
ing bus between the disc com roller board and the first disc drive 
could have been extended to the second drive in a daisy chain 
fashion, With this configuration , I wo problems would be encoun- 
tered First, monitoring media changes on both drives would not 
be possible. Second, when the drive select is changed a delay is 
incurred in waiting for the selected drive to become ready. 

Instead of daisy chajmng, a second drrve cable was added. 
This permits separate monitoring of media changes and readi- 
ness for the drives, wrth the resl of the controller logic being 
shared With this design, media changes can be monitored by 
software and the drive select can be changed without waiting. 

-Steve Chorak 
-Jon Rubinstein 



heart of both computers is a 6800U microprocessor chip 
interfaced to a 100-pin memory and I/O [input/output) bus, 
Also standard is a keyboard with ten (20 with shift) user- 
definable softkeys, a built-in 1 IP-IB* interface, a real-time 
clock, a programmable beeper, and a graphics display sys- 
tem (400 x 300 pixels for the 98 26 A, 512 x 390 pixels for the 
9836A]. In addition to the standard ASCII** character set, 
keycap labels and character sets are available for French. 
Herman, Katakana (Japanese), Spanish, and Swedish- 
Finnish. 

A knob on the upper left-hand corner of I ho keyboard 
provides both programmers and operators an input device 
with an analog feel. When editing programs, this device is 
connected internally to the CRT display's cursor for scroll- 
ing program lines or moving the cursor to a particular 
character within a line, Information about the knob {din , - 
Hon and amount of rotation) can be obtained by program 
statements and used to control instruments [e.g.. gang-tun- 
ing a synthesizer/analyzer combination] or computations 
(e.g. T adjusting a component value in an active circuit while 
continuously plotting the frequency response), 

•Hewlett-Packard Interface &us HP s implementaiion ol IEEE standard 488 
"American Standard Code lor InformartDn tru&cfcange 



Programming Languages 

The 9826 A and 98 3 ft A Computer Systems can be used 
wilh any of three programming languages — BASIC, HPL, 
and Pascal [see article on page 24). 

BASIC provides an enhanced capability set to serve a 
variety of customers from first-time users who appreciate 
simple BASIC constructs and friendly program develop- 
ment to advanced programmers who appreciate fast, 
sophisticated functions and subprograms and the unified 
I/O and mass storage. Unified I/O means that all I/O opera- 
tions appear to be the same to a programmer and can be 
easily redirected to different devices (e.g, P to a printer or a 
disc file; from an instrument, keyboard, or disc file). 

HPL is a very compact and efficient algebraic language 
first used by Hewlett-Packard on the 9820 and later on the 
9825 Desktop Computers. The version used in the 9H26A 
and 9B36A provides a high degree of compatibility with 
existing 9825 programs, fiies, and interface capabilities, a 
significant improvement in execution speed, and several 
new HPL features such as a lull- sere en editor, CRT 
graphics, real-time clock, and access to the knob functions. 

Pascal h a highly structured, modular programming lan- 
guage that provides compiled speed and program de- 
velopment contributions not found in other Pascal im- 
plementations. Pascal programs are directly compiled to 
68000 link form and are automatically linked by a librarian 
routine which makes it easy to put together sophisticated, 
modular systems. 

The 9826A and DS36A offer users a flexible set of pro- 
gramming language choices; each language is capable of 
running on the mainframe and it is possible to order another 
language as an add-on capability at any time. To provide 
more user flexibility, some of the languages are available 
"hard" in ROM (read-only memory 1 as well as "soft" to be 
loaded into RAM [random-access memory). For instance, 
users who intend to write most of their programs in BASIC 
but occasionally use HPL are able to purchase hard BASIC 
and soft HPL. The wakeup configuration of the system is 
determined at power-up by a small ROM (called the boot 
ROM). After initializing the computer and performing 
memory tests, the boot ROM determines which language 
system to wake up, In the 9826A and 98 36 A, soft language 
systems such as Pascal have precedence over hard systems, 
so the first item of business is to check for a disc w the 
flexible disc drive. If a disc is installed, a front-to- hack 
search of the directory is made to see if there is a system file. 
If one exists and has a file name beginning with SYSTEM— 
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Fig. 2« Program fisting in BASIC of benchmark program used 
for obtaining data given in Table I. 
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Table I 
Benchmark Performance 

Total Execution Time [in seconds): 

9825 9826A9836A 9826A9836A 9826A 9836A 

HPL HPL BASIC Pa- 

— __ _ Interpreted (Compiled) 

11.48 6,95 0.91 

of running this jimgram using snt- 

ottiCT number have been run 4.01 - 

varidbl* (ni ihr I [Mi; ntcger tu*lM v Aruhlrs [ A.fc , *nd 

L| =8J-iti integer math whptevft possible ]itu hiding integer divide fDIV'i instead at 
flostj ng-pnml drvidel I in line 60) 



this soft system is loaded into RAM and given control. if no 
system files are found on the disc (or no disc is installed), 
the boot ROM searches from low memory towards high 
memory looking for the ROM header of a language system. 
It it Buds one, it continues searching (on IGK-byte bound- 
aries] to see if there is more than one hard system. If only 
one hard system is found, this system is given control and 
the computer wakes up in that language. If more than one 
hard language system is found, the user is given a choice of 
which one to turn on. For example, if BASIC and HPL are 
both installed in ROM, the user responds to a prompt with B 
lor BASIC or H for HPL. If no hard or soft language system is 
found a message is displayed indicating this fact; the user is 
told to push RESET (SHIFT PAUSE) to try again. 

Besides this procedure H the hoot ROM also interrogates 
the hardware and sets up a hardware-attribute table foj 
by the language systems, This table defines the al- 



phanumeric screen width, the graphics size* and the inter- 
nal disc configuration corresponding to whether the prod- 
uct is a 98 26 A or 9836A. This provides the language sys- 
tems with the necessary information to configure them- 
selves for either of these two products. 

In addition to friendliness, excellent 1.0. and graphics, 
fast execution speed was one of the goals for each language 
implementation. Table I shows the total execution time for 
each \ language configuration (as well as the 

9825 1 when running a simple benchmark program. 1 (We 
have only shown the listing of the program in BASIC in Fig. 
2. However, it represents the algorithm used by all of the 
languages). 

Versatile Backplane 

The backplane of the 9826A and 9836A has eight user- 
accessible slots. Up to four (every other one) of these slots 
m used for any of the many high-performance interface 
cards that are available (see Fig. 3). The remaining four slots 
can be used to install RAM. ROM. andor DMA (direct 
memory access) cards. 

The interface cards (see article on page 17] im hide the 
HP-IB card which is essentially identical to the built-in 
HP-IB port and can be used in conjunction with a dual-port 
DMA (direct memory access) card to provide data transfei 
speeds of 200K bytes per second and a complete IEEE-488 
implementation. The 16-bit parallel GPIO card provides all 
functions implemented on its predecessors and supports 
DMA rates up to L5 megabytes per second. A high-speed 
serial card with on-card buffering and a 19,200-baud trans- 
B i i tic handles many asynchronous protocols and the 
Hewlett-Packard Distributed Systems Network Datalink 
(nSNDLj protocol. Also available are an RS-232-C card 




Fig. 3. The backplane of the 
982&A and 9836A mainframes ac- 
commodates up to four HO inter- 
faces and four RAM, ROM. or DMA 
cards in addition to the interna! 
HP- IB 
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designed to interface terminals and printers, and a BCD 
(binary- coded decimal) card for reading information from 
bit-parallel BCD instruments. 

I/O Performance 

important operations for controllers include the ability to 
do short I/O transactions quickly with a minimum of over- 
head [such as outputting a short alphanumeric string lo 
select a channel on a relay scanner, or entering a reading 
from a voltmeter] . One of the tests made to determine the 
effectiveness of the implementations was the Nelson 
Benchmark (see Fig. 4) named after our lab manager Jerry 
Nelson, one of the inventors of the HP-IB, who devised the 
experiment. The equipment consists of an HP 3437A Sys- 
tems Voltmeter, a 3495 A Relay Scanner, and a 982BA Com- 
puter System. The voltmeter/scanner combination mea- 
sures the voltage at each node of a biased resistor stick (10 
resistors of equal value connected in series). The execution 
time required to determine expected values, measure the 
network, and check each measurement against a limit is 
listed in Table II for each language configuration, 

Table II 
Nelson Benchmark Performance 

Execution Time [in seconds): 

9H25 9826A/9S36A 982BA/9336A 9B26A/9836A 

HPL HPL BASIC Pascal 

— — Interpreted- — — [Compiled) 

0.113 0,092 0,077 0.038 

NOTM: The limed portion f Fig.. 4| is the call in "C»jt ri?ai"lini*s'".."ani] the limjM'.ontarrted tn 
linos 13t>thrnugh ]7ft. T1«e liniti kir compiled Pascal includes some hand -tuning of the 
measurement cnUs and a spenLsNy wrilh:ii riinhm: In nmvert llie DVM readhiKS into 
integer tormsc Integer math could be used. This is a good ftxaraplfl of what i^ passible in 
Pa&caJ when used by someone ivho understands the application ■ i ■ i > I idn u'\U\r \\\e. 
prOgrfltD rti gordiugl) . I ts£ttjj tin- standard 1/Q library, the execution time lor Pascal was 
01 1 seconds. 



Many Peripherals 

The 91:126 A and 9836A have excellent capabilities lo con- 
trol the many hundreds of 1EEE-4H8 [HP- IB) instruments. 
Also, several important peripherals are fully supported (in- 
cluding lull system testing]. In the hardcopy area, the sys- 
tems can use the IIP 9866B, 9876A, 2G71A/G and 2673 A 
printers. The new IIP 2670 Series Printer family is designed 
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to sit on top of the mainframe (see article on page 22]. In 
addition to raster-dot graphics dump supported on the 
9876A, 2671C and 2673A printers, high-quality vector 
plotting can be accomplished on the 7 225 A and 9872B/C 
X-Y plotters, and graphical input is supported from the 
91 1 I A Graphics Tablet, Current disc support includes the 
HP 82901 (dual drive] and 82902 [single drive) 5.25^in 
flexible disc drives, and (he 9895A 8-in flexible disc drive 
(for both single-sided and double-sided discs). 

Applications and Utilities 

Many application programs are available tor these com- 
puters and many user programs can be adapted from other 
computers, BASIC utilities are available to do disc backup, 
cross reference, and secure a program from listing. A train- 
ing disc demonstrates the machine's capabilities. Programs 
to translate from other HP implementations to 9826A/ 
9836A BASIC are available. Applications for BASIC in- 
clude a complete statistics package, a program management 
package, and VisiCalc™, 

VisiCaL. ;i a Irademark of Vis i Cor p. 



John L Bidwell 

John Bidwell joined HP in 1 970 and has 
worked on various aspects of the 9830, 
9835, 9345 and 9826 designs. He was 
project manager ot the interpreter 
group for 9826A BASIC John received 
the BS degree in mechanical engineer- 
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on one patent related to the 9845 Com- 
puter. A native of New York City, John 
and his seven-yea rold son live in Fort 
Collins, Colorado. John enjoys bicy- 
cling, motorcycle racing, sailing, and 
playing tennis. 
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Fig. 4, Partial fisting of the Nelson Benchmark program used 

to obtain data given in Table U. 
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ming computers. 
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one of ttie co-inventors of the HP-JL 
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HPL has several utilities, including disc backup. Pascal 
has utilities as part of Ihe system library to do HP- IB instru- 
ment I/O. other interface L'O, a subset of DGL graphics as 
used on the HP 1000 Computer, and mass memory man- 
agement. 
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Hardware Design for an Integrated 
Instrumentation Computer System 

by Don D. Stewart, Robert J. Horning, Ken L, Burgess, 
Ronald G. Rogers, and James W, Mc Lucas 



THE DESIGN GOAL for the HP Model 9826A Com- 
puter System was to replace the 9825 Desktop Com- 
puter with n product having twice the perfor- 
mance at about the same price. This meant not only better 
than two times the speed of the 9825, but also better than 
two times the overall functionality, Friendliness, and 
reliability. The 982GA has these features, can be operated 
with several software languages, and is contained in a con- 
venient package that can be rack mounted or stacked with 
other instruments. 

A block diagram of the 9826A hardware is shown in Fig. 
1 The hardware tot the 9B£6A is similar, differing only in 
having a larger GRT and another flexible disc drive, The 
CP1 1 used by both systems is the 16-bit HBOOU microproces- 
sor. The following attributes made this part an attractive 
choice: 



■ Versatile 16~bit-external'32-bit-internal architecture 

■ 16- megabyte linear address space 

■ Memory-mapped I/O 

■ Powerful instruction set with 14 addressing modes and 5 
main data types 

m Seventeen 32-bit registers in addition In the 32-bit pro- 
gram counter and a 16-bit status register 

• High-performance. ti-MHz operation 

• Opportunity for 9826A/9836A family growth as the 
66000 family evolves. 

The input and output signals of the 6800Q are shown in 
Kig, 2-, Thr processor status bits indicate Hie state and the 
cycle type currently being executed, The 6800 peripheral 
control signals are included to allow for backward com- 
patibility when interfacing to 6800-family peripheral de- 
vices (e.g.. the 9826A display controller). The system con- 



CPU Board 




Bool ROM 

On -Board 
RAM 






Cardcage Common Bus 



Suffers 



Upper Dala Bus (DB-015) 
I Lower Data Bus (D0-D7) 



or 



Fulure Oplion 



Fig. 1 . Block diagram of 9826A hardware system 
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trol inputs are fairly standard with the exception of bus 
error. The bus error input BERR informs the processor that 
there is a problem with ihe cycle being executed. Upon 
receipt, the 58000 aborts the cycle, places information on 
the stack regarding the incompleted cycle, and branches to 
a software bus error handling routine, In this way an intelli- 
gent response to an incompleted cycle is possible. The 
address bus is capable of addressing 8 million words of data 
and the data bus provides a general-purpose 16-bit data 
path. The asynchronous bus control lines supply the neces- 
sary handshake to coordinate a data transfer. The bus arbi- 
tration control lines determine which device in the system 
will be the bus master. Finally, tbe interrupt control input 
lines indicate to the 68000 the encoded priority level of the 
device requesting an interrupt. 

The hardware system's address and data buses are simply 
the buffered form of the 68000 + s address and data buses. 
Except for a few special-purpose additions, the same situa- 
tion applies to the control and interrupt lines, 

Memory Map 

The system memory map is shown in Fig. :j, The first four 
megabytes are assigned to system ROM and the boot ROM. 
This part of the address space is a synchronous response 
area. When the CPU board recognizes an access to this 
address range, it internally sends a DTACK (data transfer 
acknowledge) signal to the 6 80 GO which creates a five- 
clock-cycle access. This automatic DTACK mechanism is 
used because ROMs are synchronous devices. It avoids the 
need for duplicating a fixed-delay or DTACK circuit on each 
of the ROM cards. Instead, this function is centralized on 
the CPU board. 

Two ROM cards are available; a 128K-byte ROM board 
with sixteen 8K x 3 ROMs and a 512K-byte ROM board with 
sixteen 32Kxe ROMs. 

The next four megabytes are assigned to the internal and 
external I/O spaces. Fig. 4 shows the bit assignments for t lie 
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Fig. 2. Input and output control stgnats for the 68000 micro- 
processor. 
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Fig, 3. Memory map for 9826A and Q836A systems, 

internal and external I/O accesses. 

The four megabytes available lor 10 are mapped into 32 
select codes with 64K bytes of address space each. Hence, 
only two of tbe megabytes are actually used. Select codas 
through 7 are used by internal devices and select codes 8 
through 31 are used by external devices. The 9826 A and 
9H36 A operating systems automatically convert the user- 
nut ered seleel code into the proper memory address; that is, 
for select codes through 7 t bit 21 is set to zero and for select 
codes fi through 31, bit 21 Is set to one. Thus, if an external 
I/O card is set by the user to an internal select code number, 
the card will never be addressed by the operating system, 
This eliminal est lie possibility nt an external card's Irving to 
communicate on the bus at the same time as an internal 
card. 

The internal I/O space is broken into synchronous and 
asynchronous portions. The asynchronous portion requires 
thai the internal peripheral respond with DTACK in much 
the same manner that external peripherals and the read' 
write memory card do, Internal peripherals residing in the 
synchronous portion o( the address space use the automatic 
DTACK mechanism, much as the system and boot ROMs do. 
However, in this space, the number of clock cycles for 
access by the CPU board is program mable from five to eight 
cycles via address bits 14 and 1 5, 

The next megabyte in the address space is used for HP's 
internal testing and monitoring, The remaining seven 
jabytes in the address space are reserved for RAM. 

CPU Board 

The CPU board (Kig. I) contains two BKxtf boot ROMs. 
These ROMs contain the 68000 reset, interrupt and other 
exception vectors as well as the necessary information to 
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Fig. 4. Address bit assignments for internal and external 10 
accesses. 

initialize the system on power-up and begin execution of 
the appropriate language system. The 68000 requires that 
these two ROMs reside at the very bottom of the address 
space (Fig. 3) T 

J In CPi board also contains a 64K-byte block of read' 
write memory. This block of memory has the novel ability to 
locale itself in the address space automatically as the 
■st -address block of HAM in the system. This capability 
is necessary because the memory address switches on the 
CPU board are not accessible to the user Furthermore, 
flexibility requirements of the system necessitate that the 
I J'l board RAM be relocatable and self-configuring. When 
the system is powered up, the memory block is disabled by 
the autoiocate circuil shown Ln Fig. 5, This prohibits the 
memory block from appearing in a random location depen- 
dent upon the power- up state ol the D-typE Hip-Hups. Fig, 
6a shows the power-up signal conditions for the circuit in 
t'ig. n. Should an access to a memory location occur that 
would create a comparator match, CS is still disabled I Fig. 
6b) until memory-block-select enable (WAJCEUP) becomes 
valid [Fig I- hi thai the operating system is 

to begin accessing memory for power- up routines. 

An early activity for the operating system at power-up is 
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Fig, 6. Timing diagram for autofocatmg circuitry 

to determine the amount ofava liable memory in the system 
by beginning to search at the top of the address space and 
then searching down until the first vacant location is found. 
At this point, a bus handshake timeout RIPC occurs, indicat- 
ing that no memory is present to respond. The circuitry 
intercepts this signal and fills this first vacant location (Fig. 
tic). The memory block controlled by the autolocate i 
tronics responds and the operating system continues the 
search for another vacant Ideation, finally, a second vacant 
location is encountered. This time the circuit sends the RIPC 
signal on through as a bus error BERR (Fig. 6d). The system 
then logs this information and continues normal program 
execution (Fig. 6e). Jn this way, the controlled memory 
block is automatically assigned to the first vacant location 
in the address space without user or special operating sys- 
tem intervention. 



Power-Up 
Reset 

<PUHESET) 



Bus Handshake 
Timeout 

tPJPC] 



Address Lines 
(A17-A23) 



Address Valid 




Memory-Block- 
Select Address 
(QO-07) 



H 



Comparator 



Valid Compared :G> 



Bus Error 



Memory 
Block Select 



Fig. 5. Simplified block diagram 
of autoiocatmg electronics for 
CPU memory block, 
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Product Design for Easy Production 



The product concept of the 9826A and 9S36A diverges some- 
what from that of traditional HP desktop computers. The require- 
ment of achieving a performance/cost ratio up to five times higher 
than for previous products was not, by itself, unusual. However, 
the 9826 A and 9836 A also are intended to become benchmark 
instruments in other ways such as simplified assembly and servic- 
ing, testing, reliability, high-volume production, portability in a 
highly integrated product, innovations in EMI/RFJ protection, and 
visual compatibility with rack-mounted instruments. 

Low Cost— High Volume 

Creating a low-cost package was compatible with the expected 
high volume because higher volumes can justify higher expendi- 
tures for tooling Complex molded plastic parts were designed to 
combine as many functions as possible and to eliminate sheet- 
metal parts. Details are molded into the plastic parts so that an 
absolute minimum of fasteners is required. 

In many instances, a standard component is used as a pri- 
mary structural member instead of adding another part. For exam- 
ple, the cooling fan acts as the structural member of an assembly 
that mounts the fan to the base, supports the large dc fitter 
capacitor in the power supply, provides guides for four printed 
Circuit boards, and divides the flow of cooing air for the different 
sections of the instrument 

The rear panel, molded into the structural foam base, is unsup- 
ported rn a front-to-back direction. The molded printed circuit 
board guides are unsupported in a side-to-side direction. How- 
ever, joined together, these elements become a rigid structure. 
The power transformer depends heavify upon mounting to the 
fragile rear panel, but imparts massive strength to the assembly 
by acting as a support member. 

A single molded plastic pan mounted with two screws under 
the keyboard, provides a retainer and guide for the power switcti 
button, mounting (with no fasteners) for the power switch, a 
hinged safety cover for the power switch terminals, and a red 
visual indicator to signal the on position to the operator 

The externaf package is formed by four structural loam- 
mounted parts held together by eleven screws. Efforts were made 
throughout the design to eliminate hardware and reduce the 
number ot parts. Where it was practical ana use f ui, modular 
subassemblies were created to reduce assembly labor. 



Reliability 

The necessary proof of mechanical reliability is extensive test- 
ing . It was presumed that reducing the parts count would increase 
reliability, but the challenge lies in maintaining sFructural integrity 
while eliminating fasteners. It is much easier simply to add another 
screw or another pan. To put it another way. scmplified designs 
are the hardest to execute. 

Early in the project it was decided that extensive testing with 
real molded parts would be essential to achieving both struc- 
tural simplification and reliability- A year before production 
release, temporary molds were tooled up for all major plastic 
parts. This allowed testing and modification using actual parts 
before commrtttng to production tooling Sometimes the results 
eliminated more hardware than anticipated, and sometimes criti- 
cal weak points were discovered early But most important, tne 
result is a deceptively simple, reliable product. 

One of the major benefits of early testing was in the area of 
cooling. Some early discoveries and decisions were made, a few 
of which are controversial. 

On the 9826A and 9836A. the cooling fan blows out, rather than 
m. This disallows the use of a filter because it is not necessary to 



filter the air going out of an instrument and filtering all of the an 
entering the instrument is impractical. A filter would also decrease 
the cooling efficiency of the atr flow. A filter can become clogged if 
not serviced periodically, causing damage through overheat- 
ing 

The advantages are appreciable. Farst of all, the heat of the fan 
is kept out of the product Also, since the power supply area 
generates the most heat, this hot air is drawn out immediately, and 
not subsequently into other areas of the instrument Cool ambient 
air is drawn in through natural openings such as the keyboard, 
side vents, and l.'O panels, and tt flows over the tnternal compo- 
nents and circuit boards on its way to the fan Most of the air is 
channeled through the power supply area at high velocity, and 
combined with a custom-designed heat sink, selves to maximize 
heat transfer from the power supply. 

The air flow is allocated to various sections of the product 
according to tested need. Two methods were used to determine 
this. Component temperatures were monitored under diverse 
conditions, and smoke was used to determine air flow patterns 
and relative velocities In the smoke tracing, transparent case 
parts allowed visual observation of air flow. 

The individual I/O modules are kept cool by incorporating them 
into the internal air flow pattern, rather than treating them as 
external plugnns, as was done on other HP desktop computers. 
They remain user-removable from the rear panel. 

Industrial Design 

The 98 26 A and 9836 A are desrgned to be rackable/stackable 

and visually compatible with other HP rack-mount instruments. 
The products have their own beauty as stand-alone desktop 
computers, blending into an office environment quite naturally 
but the crisp lines were originated with instruments in mind. 

Standard rack-mount dimensions are maintained, and the in- 
ternal peripherals (CRT display, flexible disc drive) are integrated 
into a package only 1 8 cm high (45 cm for the 9836A) The power 
switch is located on the front of the keyboard and the knob is 
positioned at the upper left corner of the keyboard for convenient 
user operation. The front panel of the CRT display is slanted back 
at 10° for proper user viewing angle. 

Stacking an instrument on top of the 9826A or the 9S36A, the 
user finds that a standard stacking recess (slot) is provided, 
matching the special feet on most HP instruments, and locking the 
two together 

Production Engineering in the Lab 

There were certain priorities for the 9826A/9S36A project that 
required more than the usual design function Early in the project, 
a separate lab group was created and chartered to design the 
production process. This included such tasks as assembly pro- 
cedures, ease of assembly, oroduction testing, simplification of 
servicing : and the tools and fixtures for assembly Production 
changes alter introduction were to be avoided by including pro- 
duction engineering during the design phase, rather than later 

Numerous design details were modified early as a result of this 
approach. What may seem to be easy on paper, or even on a 
prototype, may not be so perfect in the real world of high -volume 
assembly. For example, one screw that is accessible but awk- 
ward to reach may seem to be a trivial problem to the designer but 
its awkwardness is magnified many times to the assembly or 
service person who has to deal with it on a daily basis. 

EMI Innovations 

Much research and experimentation had taken place previ- 
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ously or EM - - : :erterence) reduction It was felt 

thai, ii should be possible to design an instrument with 

try, sucfi that the surrounding enclosure need only sen* as 
a container and provide visuat and mechanical tunc 

~- . nques w^ 3 E-Ml at the source, such 

as Signal shaping, use of ground planes, and elimination o* tong 
rtors that act as broadcast antennas What was not Known 
was how much noise could be eliminated at the so 

The approach taken was a conservative one. It was assumed 
g effort to reduce tne sources would be ineffective, and so 
the case parts were designed to delude total zinc arc-spray 
coating on the inside full conducive gasketmg between all parts. 
and complete grounding everywhere Then, when all shielding 
provisions were in place, the entire design group was encour- 
aged to ignore them and independently design for tow EMI (out- 
put and susceptibility). All boards and subassemblies were 
range-tested and modified numerous times to eliminate EMI 

The result is that only mimmaJ external shielding is needed The 
zinc arc-spray was replaced by inexpensive conductive paint 
The fufl conductive gasketing was eliminated. Only six contact 
points are needed between case parts— the 9 826 A and 9836A 
can pass VDE and FCC requirements without them, but they 
increase the design margin. 

Another cost-saving benefit of early EMI testing was in the area 
of CRT shielding, A CRT shield is needed to eliminate the potential 
effect of stray CRT magnetic fields on the flexible disc heads. 
Instead of assuming the need for a very expensive mu-metal 



shield over the CRT and flexible disc - - e were 

ied to estabNsh what configuration and material would do 

the best job At me frequencies and field orientations involved . the 

ed using a partially open aluminum 

shield, which happened to be a very inexpensive ete 

The success of the EMi design, as well as that of the other 
>nnovs ■ oned here, rests primarily with the concept of 

very early testing There ss much to be learned from testing, and it 
is not necessary to wait for production- ready parts to sta 
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Read/ Write Memory and DMA Boards 

At introduction the 9826A was able to support about 
one-half megabyte of RAM. Since introduction new 
technology has allowed the original 64K-byte RAM board 
using 1 6K-bit dynamic RAMs to be replaced by a 25BK-byte 
board ttsl&g f>4k-bit dynamic RAMs, This expands the 
maximum syslem memory size to more than two mega- 
-, Only the 256K-byte board (Fig. 7) will be discussed in 
detail. However, the G4K-byte board is very similar in ar- 
chitecture, 

The RAM boards can be plugged into any of the eight 
backplane slots* They can run regular asynchronous 
shs ,)! a speciaJ synchronous access. When a RAM 
board runs an asynchronous access the data will be valid on 
the bus for 50 ns before the board pulls the data transfer 
acknowledge (DTACK) line low. During a synchronous ac- 
cess the 68000 CIH ] does not clock data until one clock cycle 
after it detects DTACK, If DTACK is given after data becomes 
valid, One clock cycle ol access time will be wasted by the 
internal timing of the CPU. By giving a synchronized early 
DTACK the synchronous accesses will run two clock cycles 
faster than a normal asynchronous data transfer (five CPU 
clock cycles instead of seven). The board is synchronized 
with the CPU by use of a signal called ENfDT (enable DTACK]. 
This is a bus signal provided by the CPU that is gated into 
the CPUs DTACK input by the RAM board to generate a 
five- cycle synchronous access. 

The CPU normally runs synchronous accesses with the 
RAM board. However, if the dynamic RAMs are being re- 
freshed when the access begins, the access is delayed and 
synchronization with the UP! f is lost. The RAM board must 
then run an asynchronous access. 

The DMA [direct memory m :.ml always runs 

asynchronous accesses with the RAM hoard /This allows for 



a low-cos [, high-performance DMA design. The low cost is 
achieved by supporting only one type of DMA cycle for both 
low-speed and high-speed I'D cards. The high performance 
is realized by starting the memory access in parallel with 
the 10 card access, This requires that, on writes to the RAM 
board, the RAM board be able to complete the access up to 
the point where data is supposed to be valid, and then wait 
for the data strobe* 

Since refreshes are generated by a state machine lh.il is 
not synchronous with the bus 1 it is necessary to use an 
arbitration circuit that prevents glitches or astuble signals 
from getting into the RAM control circuitry (see Pig. 7]. 
Dynamic RAMs can lose data if the cunt ml signals are 
gl itched or the address lines are not set up or held properly. 
The refresh circuit does the arbitration by holding off any 
new accesses and waiting for any current access to end. 
ties are prevented by useoi the open-collector gate, the 
RC network, and the Schmitt trigger latch shown in Pig 7 
The RC network stretches the pulses to ensure that any 
signal that conies out of the open-collector gate will be long 
enough to set the Schmitt trigger latch. 

Keyboard and Real-Time Clock 

The circuitry for the 9826A/983GA keyboard, knob, pro- 
grammable audio alarm, and real-time clock is based on an 
804 1 A microprocessor. The main focus of the design was to 
minimize cost and maximize reliability, The H04 1A was 
chosen as I he microprocessor because it is low-cost and 
designed to be slaved to a master processor. This allows it to 
be interfaced to tin- 68000 with minimal circuitry, 

The keyboard has LQ3 keys plus shift and control. The 
9826A and #83 6A have keyboard options for German, 
I i'inli. Spanish, Swedish/Finnish, and Katakana 
I Japanese], The system language and configuration jumpers 
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14.5V during battery operation, 

To meet these requirements, conventional switching 
regulators are used to implement the +5V and +12V 
supplies, and a dc-to-dc converter is used for the -12V 
supply. The dc voltage to the regulators is provided by a 
transformer-isolated, full-wave-rectified supply with a 
nominal voltage of 28Vdc so that transfer to the battery can 
be simple and practically instantaneous. 

Short-circuit protection is provided for all three supplies, 
and overvoltage protection is provided for the -»-5V and 
+ 12V supplies. The -12V supply does not need overvolt- 
age protection because its design provides inherent protec- 
tion against shorted switching transistors. 

The powerfail option to be available in the near future 
(Fig. 10) will allow the 982GA to ride out short power 
interruptions and power down in an orderly manner when 
power interruptions last longer than a few seconds. With 
this future option the entire machine can be operated for up 
to 60 seconds after Joss pi $£ line power, allowing the user to 
store important data on flexible disc before powering down. 
The power fa il option also w ill contain a real-time clock and 
112 bytes of memory. The amount of powerfail protection, 
the amount of time that power must be gone before giving a 
powerfail interrupt, and the amount of limit that power 
must be back before leaving the powerfail state will all be 
programmable between and 60 seconds. These pro- 
grammable features and the real-time clock use another 
8041 A microcomputer to control the powerfail system, 
Analog comparators will monitor powerfail and battery 
conditions and provide this information to the 8041 A, An 
lB-volt T 2-ampere-hour nickel-cadmium battery will pro- 
vide power to the system for a short time after the power 




Future Powerfail Option 



Fig, 10. Block diagram of power supply and optional power- 
faff circuit. 



fails and to the real-time clock and CMOS* memory when 
the power is off, 

It will be necessary to have a switch ganged with I he 
power switch to tell the difference between a powerfail and 
the system being turned off. This signal will go to the 8041 A 
powerfail controller but also will override the controller 
and shut off the system if the power is turned off. Thus, 
even if the controller fails the pow r er switch will turn off 
the machine. 

The battery will be connected to the unfiltered 28Vdc 
supply through a transfer diode and relay. The relay will 
close at power-up , providing nearly instantaneous protec- 
tion through the transfer diode when power fails. The relay 
will open at power- do vvn so the controller does not have to 
be pow r ered up and leakage into the power supply will nut 
drain the battery. The battery will be charged by a 
constant-current charging circuit powered from the unfil- 
tered 2ttVdc supply. Typical recharge time for a fully dis- 
charged battery should be 14 hours. After a 60-second 
backup cycle is provided by the battery it will still be 
able to keep the real-time clock and CMOS memory operat- 
ing for a week. 

The power will be monitored in three different ways. The 
ac on the secondary of the transformer will be monitored to 
see whether any cycles are missed. The unfiltered 28Vdc 
supply will be monitored to detect reductions of more than 
10% in the ac line voltage. Either one of these conditions 
will be considered a powerfail by the controller, The operat- 
ing system can interrogate the controller to find out the 
reason for the powerfail. The unfiltered 28Vdc w T ill also be 
monitored to check whether the battery is discharged to the 
point where it will not be able to provide the 14.5V required 
by the regulators, When this signal is received the con- 
troller will shut dowm the regulators, 

The 8 041 A controller and the monitors will be powered 
by their own +5V regulator. This will allow the controller 
toTemain operational until the rest of the system is powered 
dowm, When power comes up the controller will monitor 
the power until it is valid (has proper voltage). When power 
becomes valid the battery charging relay will be switched 
on and the rest of the machine powered up, The controller 
will be programmable to give interrupts to the operating 
system for powerfail or power coming back. The operating 
system will be able to send a command to the 8041 A to shut 
down the power at any time, This will allows a user to 
conserve the powerfail battery charge if the user's graceful 
power-down routine takes less than the fiO seconds al- 
lowed. When the power is shut down for any reason (com- 
mand, switch off, protect time up + or battery discharged) the 
regulators will be turned off and the charging relay opened 
after a delay. The delay will ensure that the current through 
the relay is very small when it is switched, thus improving 
the reliability of the relay. 

Real time will be kept by use of a CMOS counter and a 
CMOS RAM powered by the battery at all times, 1 12 bytes of 
the CMOS RAM will be available to the operating system or 
the user to store system configuration information. 

Quality and Reliability 

An early commitment was made to invest resources to 

■ Complementary rra T& conductor 
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Instrument Burn-In 



The concept d burrvin testing for production instruments has 
: Orrgtna'i , educed to screen out 

unwanted infant failures in the field, but since has beer 

•ting. In ftgnt of recent efforts to 
le productivity by optimizing the production proce ~. 
process (WIP) 
aQing pnitosppriy rightfully nas come under attacK because the 
cost to repair production failures at the instrument level adversely 
affects the goal o* reduced Wl P, An obvious objective would be to 
test for and eHmsnate failure mechanisms at an earlier poir- 
process. The difficulsy in achieving this objective is that rt requires 
an understanding of just what is causing infant instrument failures. 
This in turn demands that exhaustive and accurate failure analysis 
be performed on faifed assemblies to identify what tests could be 
performed earlier in the production cycle to exercise the predom- 
inant failure mechanisms. 

In defining a production test plan for the 9826A Computer 
System, attempts to gather data in support of one test philosophy 
over another proved to be unproductive, it soon became appar- 
ent that additional failure analysis data was required to define 
accurately what earlier tests would be effect we 

Since the ultimate goal is to minimize field failures, it was con- 
cluded that instrument burn-in would be the most representative 
indicator as to what failure mechanisms should be exercised. 
However, considering the ultimate goal of earlier testing, certain 
guidelines had to be established that would ensure proper use of 
instrument burn-in: 

• Be comprehensive in developing the burn-in plan. Variation of 
environmental parameters such as temperature, humidity, and 
power provide a versatile and powerful test capability. 

• Do not let instrument burn-in become a screen. A screen tends 
to become a permanent and unwieldy part of production Tfts 
goal is to eliminate the instrument- level burn-in. 

■ Failure analysis of failed assemblies and components is vital in 
determining failure mechanisms and is crucial to identifying 
whether or not testing earlier in the production process is feasi- 
ble and.'or economical. 
The 9826A burn-in plan is an evaluation tool that is used to test 
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Fig, 1 * Instrument bum-in monitoring system. 



the manufacturing process whrch is made up of several testable 
parameters: design, material, and workmanship. The source of a 
production failure will be ultimately identified as one of these 
parameters and action will be taken to adjust the process at the 
earliest point possible This may result in adjustments being made 
by the component vendor, or at incoming inspection, board load- 
ing, or board test areas 

Assuming that this philosophy is administered properly, it 
naturally will result in reduced need formstrument-fevel bum-in as 
more and more problems are eliminated 

The resulting 9626A burn-in program incorporates several test 
environments: 
• Temperature cycling is used to verify proper operating margin 

m electrical and mechanical assemblies' 
m Power cycling is used to impose t he rrno mechanical stress on 
the internal construction of encapsulated components such as 
integrated circuit and other semiconductor devices 4 5 
■ Vibration testing sifts out early problems associated with in- 
strument integrity and workmanship h ; 



Day 1 1 
Day 2 
Day 31 



March April May June July Augu$l Sept Oct 

t t 

Implement 8 urn -In Plan Third Day Removed 



Nov 



Dec 



Jan 



Fig. 2. Failure rate per day of 
hum-in over an 1 1 -month period. 
The burn-in plan was implemented 
in May 1981 and the third day of 
burn-in was eliminated that Au- 
gust (Note September's failure 
rate increase was caused by a 
single vendor problem,) 
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In addition to these environmental tests, a monitor system (Fig, 
1 ) is used to evaluate the status of each 9826A. The instruments in 
Fig 1 perform the following functions. 

1 ThermotronWP-1261-TCM 3-15 Chamber: 3.35 mx 3.35 mx 
2 44 m walk-in temperature chamber designed to accommo- 
date up to seventy 9826As (of testing, With a load of 1 4 kW and 
907 kg of mass, the chamber will provide a transition rate 
greater than one degree Celsius per minute. 

2. HP 9826A Controller, provides chamber temperatufe and 
power cycling control, coordinates data flow from each 9826A 
under test, generates and formats failure reports, and backs 
up fail data en its internal flexible disc unit. 

3. HP 59501 A D-to-A Converter: converts computer program- 
ming outputs to an analog control signal for the chamber 
control circuitry. 

4. HP 3438A Digital MulUmeter measures chamber temperature 
by sensing a thermistor and then outputs the measurement via 
the HP- IB to the system controller, 

5. HP 59309A Clock Module: provides battery backed-up real 
time for the system. 

Data collected during the first eleven months of 9826A testing 
indicates tremendous progress has been made toward the failure 
rate goals. Fig, 2 shows a definite contrast in May 1981 failure 
rates as a result of implementing the burn- in plan. The data shows 
that the first two days of burn-in were so effective that we were 
able to reduce the burn-in time to two days in August 1981, 

A breakdown of the failure types found during failure analysis 
indicated that electrical failures far exceed other contributors. 



Table I 

Breakdown of Electrical Failures 

(Data through January 1982) 

Failure Mechanism Percent of Total 

Semiconductor-Hard Failures 37% 

Temperature Sensitivity 46% 

or Margin 

Other 17% 



Further evaluation of the electrical failures (Table I) indicates that 
the major portion of the failures were identified with varying temp- 
erature and were intermittent m nature. 
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make the 9826A and 9S36A very reliable products of high 
quality. Quality was not perceived simply as a set of tests to 
pass at the conclusion of the design cycle, but rather as a 
viable design parameter to be factored in during the de- 
velopment from the first hand-drawn sketch to the final 
product coming off the assembly line. 

An early decision was made to use multilayer printed 
circuit logic boards that include a +SV bus and ground 
plane. Even though this conflicted with our goal to keep the 
factory cost as low as possible, the gain of having a system 
immune to noise and generating minimal EMI (elec- 
tro mag net k; interference) was worth it. Mext. a decision was 
made to minimize the number of shared clocks in the sys- 
tem. Furthermore, the card cage does not receive any clock 
and has an asynchronous bus. Had this not been done, the 
8-MHz CPU clock \vould have had to leave the CPU board 
and travel about 20 cm across the motherboard and up the 
cardnage board. Then the CPU bu;inl and up to eight 
cardcage boards would all have been pulsing currents and 



switching voltages on the same clock edges. This was not 
consistent with our desire to have an EMI- quiet system, 
Finally, starting with our first wire- wrap system, we tested 
our units on I he EMI raiii^e to determine it our theories were 
indeed yielding the results we intended. 

An infrared thermal scanner was used to identity 
hardware components operating at elevated temperatures. 
This is important because semiconductor component relia- 
bility is related to temperature, The results of this test caused 
several component circuit design changes to be made. Al- 
though these weak areas probably would have shown up in 
later tests, the thermal scan quickly identified them early in 
the design process. 

Other design activities concerned with quality included 
early environmental testing and margin testing to failure of 
parameters such as power supply voltages and clock fre- 
quencies, These tests helped solve the most serious design 
problems early and provided the time to attack less fre- 
quently occurring problems, This procedure allowed us to 
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go into our major strife test program with fairly reliable 
machines, 

The strife test program was an extension of similar testing 
done on the 991 5 A Modular Computer. 1 The purpose of the 
strife testing is to identify and eliminate sources of failure 
before the product is released. Thirty-six 9826As were 
tested for about 20 days of test time per unit. The tests 
resulted in 311 failures that were categorized into 173 de- 
sign, 99 material, 26 process, and 13 test-related deficien- 
cies, 

Initial field warranty data indicates that the failure rate 
for the 9826A has been reduced by 33% as a direct result of 
design and process changes attributed to the strife test 
program. 

Reference: 

1. K. Watts. "A Unifying Approach to Designing for Reliability." 
Hewlett-Packard Journal, Vol. 32. no. 7. July 19fll. 
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I/O Philosophy and Architecture 
for Instrument Control 



by Loyd F. Nelson 



ONE AREA OF APPLICATION for the IIP Model 
9826A and 9836A Computer .Systems is as smart 
controllers, Fundamental to this application is the 
ability of the controller to he connected to all kinds of 
devices. In considering the I/O (input/output) system for the 
9826A and 9836A, the first question that arises is, "Why not 
use the current E IP 980xx series of I/O cards which already 
provide this facility?" 

Since the method of connecting external devices to the 
98 26 A and 983 6 A directly imparts the alectrieal and 



mechanical design of the machines, the quest ion of whether 
to develop a new I/O series or use the existing 980xx series 
needed an answer. An initial investigation showed that on 
the average the cost of the I O thirds could he reduced ap- 
ju ■ uimitiJy 40% by developing new designs. At the same 
performance would be improved. In the 1980s great 
competitive pressure is expected from low-end personal 
computers and the price of hardware will continue to de- 
cline. Six-year-old hardware developed for higher-priced 
products will not he competitive with the newer Inwei 
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Fig . 1 . Phystca I comp a risen of the 
older 980xx series HO card (on the 
left) and the new HO card (on the 
fight) developed for the 9826A 
and 9836 A 



generation. 

Another advantage of designing new I/O cards is the 
opportunity to improve the reliability of the cards. The 
980xx cards are housed in their own cases with no cooling 
Their form factor is such that the circuitry has to be divided 
onto two small boards (sec Fig. 1 ). The resulting design uses 
two very densely packed boards and requires many inter- 
connections as well as being troublesome to assemble and 
test. A new design should be able to solve these problems 
and contribute to the improved performance and reliability 
and would be only a small part of the total system cost. 

Physical Architecture 

Once the decision was made to develop new if.) cards, the 
physical implications were quickly decided. Rather than 
enclosing the cards in their own case, it was decided that 
the 9826A and 9836A should be designed so that the cards 
reside totally within the mainframe. This has the twofold 
advantage that the cards can be cooled by the mainframe fan 
for an increase in reliability and that more power can be 
dissipated on the cards. The power supply and cooling for 
the 9B26A and 98:*6A are designed to allow a power dissi- 
pation of 5,5 watts per card, an increase of 30% over the 
earlier 890xx series. The important +5V power supply cur- 
rent is increased from 450 milliamperes to 1 ampere. 
Added to each card is a metal backplate that connects di- 
rectly to the metal backplate of the mainframe to provide an 
excellent safety ground. 

The metal backplate, in conjunction with the attached 
metal connectors and mating metal connectors on the cable, 
also provides a significant improvement in limiting EMI 
(electromagnetic interference) radiation. Since the cable 
can be disconnected at the backplate. the I/O card is now 
independent of the cable length and the system can be 
configured easily, The space chosen for the cards allows an 
increase in printed circuit board area from 174 square cen- 
timetres for the older 980xx series cards using two boards to 
206 square centimetres for the new cards using a single- 
board design (Fig, l ). 
Electrical Architecture 

One of the keys to providing high-performance L'O for a 
lower price is the scheme by which the 68000 CPU (central 
processing unit) communicates and interacts with the I/O 
interface electronics. There are basically two schemes in 
use at HP today. The first is microprocessor based, In this 



method each interface board contains standard interface 
hardware and a microprocessor or special- purpose IC [in- 
tegrated circuit] with enough processing power to handle 
I/O- related operations. The interface between the I/O card 
and the mainframe CPU is on a relatively high level. The 
machine- level I/O code of the mainframe CPU is the same 
for all I/O interfaces, The microprocessor on each interface 
handles the peculiarities associated with the particular L'O 
protocol of the external device to which it is connected. 

The second interface method between the main frame 
CPU and the L/O interface electronics is n on structured, In 
this method the standardization of the I/O interface 
hard ware is kept to a minimum. The I/O hardware is con- 
cerned more w T ith the peculiarities of its particular external 
device and is tailored to provide those functions in an 
efficient manner, The interface between the mainframe 
CPU and the I/O card is generally on a more primitive level 
than the other method. Each signal line on the bus tends to 
have only one meaning and does not mean different things 
at different times. If there are four interrupt levels, then 
there are four interrupt-request signal lines. The software 
I/O driver is different for each interface and tailored to the 
requirements and features of the interface hardware. 

Which type oil/O interface method should be used on the 
9826A and 0&36A? This question might be best answered 
by looking at the hardware and software costs for each 
approach. In the software area the microprocessor solution 
appears to have an advantage because it provides a standard 
interface and a single standard set of I/O drivers for all 
interfaces. When a new 10 card is developed, the card can 
be inserted in the machine without having to change any 
operating system code. However, a closer look shows that 
t tie software problem is not really solved. Kach I/O card is 
different and has peculiarities that must be controlled 
by the software. The software task has essentially moved 
from writing code for the mainframe CPU to writing code 
for the microprocessor on the I/O interface card. Tools 
are needed to handle development and debugging of 
software not only for the mainframe CPU but also for each 
I/O interface microprocessor. Because the mainframe driver 
and protocol must be defined and completed long before 
the requirements of any future I/O is known, what happens 
when a new I/O card has some feature or requirement that 
cannot be handled with the defined protocol? 

The nonstructured interface hardware approach does not 
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prohibit the standardization of the mainframe L'O routines; 
it merely moves them to a higher level in the operating 
system hierarchy The 10 drivers that would have been in 
the microprocessor code of each interface move to the main- 
frame CPU and are invoked by standard L'O routines that are 
above the drivers in the operating system hierarchy, Thus, 
the nonstructured approach provides a more flexible solu- 
tion because one set of development tools can be used that 
allows the software to take full advantage of the I'O 
hardware features, 

Another consideration is how fast the software runs. The 
microprocessor on the interface card generally does not 
have the instruction execution speed of the mainframe 
CPU. In smaller machines such as the HP-85A Personal 
Computer the discrepancy in speed is not so great and, 
therefore, the extra overhead associated with the micro- 
processor on the interface card does not affect the overall 
performance of the 10. To overcome the speed problem on 
higher- performance machines, the 1/0 microprocessor usu- 
ally is not a true microprocessor but a custom 3C developed 
for that particular computer family. For the 9826A and 
9836A. the schedule and the risk associated with develop- 
ing a custom I/O microprocessor did not make it feasible. 

On the hardware side, the 9826A/9836A I/O project 
wanted to take advantage of LSI [large-scale integration) 
devices currently in the marketplace, For example, the 9914 
GPIB controller chip integrates a number of the HP-IB* 
functions and provides a flexible, cost-effective I IP- IB inter- 
face. For the I/O microprocessor approach the question 
arises as to how the LSI device and the microprocessor 
can be made to share the L'O tasks. Since the micro proces- 
sor would be located functionally between the mainframe 
CPU and the external 10 control logic, it would be awkward 
to take advantage of the control functionality of the LSI 
device. The mainframe CPU would talk to the I/O micro- 
processor and the microprocessor, in turn, would talk Jo 1 fie 
LSI device, Of course, the design could be made such that 
the mainframe CPU could also talk to the LSI device di- 
rectly. However, this would cause the standard I/O routines 
to become partially specialized, a deviation from the 
philosophy of a single set of I/O routines for all interfaces. 
Also, it would tend to make the I/O microprocessor redun- 
dant. With the nrmslruclured approach the mainframe CPU 
dways talk directly to the LSI device and take full 
advantage of its capabilities. 

Finally, for the 9826A and 9836A marketplace, one of the 
goals is to keep hardware cost down. The I/O cards should 
take advantage of current LSI devices because they provide 
mqjre functionality for the dollar as well as greater reliabil- 
ity and less power consumption than discrete MSI 
(medium-scale integration) devices, The interface ap- 
proach should minimize the overhead circuitry required. 

The BCD (binary-coded decimal) I/O card (HP Model 
UHft^MA] was designed and breadboarded using each ap- 
proach. For the microprocessor approach, an 8048 (the 
same as the series used in the HP-85A I/O] was used as the 
I/O microprocessor, It was found thai because of the inter- 
face circuitry required for the 8048 , the design needed a 
significant amount of printed circuit board space, con- 

■ i\ick*»rd Intertsft* Bus. HP's implementation ol IEEE Standard 488(t978) 



sumed more power than the nonstructured approach, and 
cost more. For the GPIO card [HP Mode] 9862 2 A) the 
amount of printed circuit board space required for the ex- 
ternal interface 16-bit registers made it doubtful that all the 
circuitry including a microprocessor couid be made to fit on 
one board. Furthermore, all the timing and control logic 
necessary to communicate with the external interface 1 6-bit 
registers was still needed to provide twice the speed of 
the 9825, and it was not clear that a microprocessor could 
be used to advantage. For the HP- IB card (HP Model 
98624A), the 9914 chip had to be used to take advantage 
of its performance and maintain compatibility with the 
internal HP- IB provided by the mainframe. 

Thus, after considering the advantages and disadvan- 
tages of the two approaches and the practical problems of 
cost and printed circuit board space, the nonstructured 
approach was chosen as the basic I'O philosophy for the 
9826A and 9S36A. 

I/O Interface Details 

The 9826A and 9836A support three types of I/O: pro- 
grammed L'O. interrupt I'O* and DMA [direct memory ac- 
cess). Fig, 2 shows the signals on the backplane associated 
with each type. Most of the signals are the signals of the 
mainframe CPU which have been buffered to provide the 
drive necessary for the bus. Because the bus is an asyn- 
chronous bus (no system clock], the presence of informa- 
tion on the address or data lines is determined from as- 
sociated control signals. Such a design is susceptible to 
skew problems between the information and the associated 
control signal caused by differences in capacitive loading 
and differences in logic path delays of the respective sig- 
nals, A significant amount of engineering time was used to 
determine the worst-case skews that could arise in the svs- 
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Fig, 2. 9826A/9836A backplane bus interface signals. 
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tern. The study resulted in a standard set of requirements for 
each entity to be connected to the bus in terms of the loading 
allowed, the drive required, the devices to use, and the 
timing to be adhered to, 

Programmed I/O 

The programmed L'O interface provides the basic com- 
munication between the mainframe CPU and the I/O. In 
keeping with the capabilities of the G8000 microprocessor, 
the I/O is accessed programme ilea lly via memory address 
mapping. Consequently, both memory and I/O cards con- 
form to the same timing specifications. Kig. 3 shows the 
signals and timing of Hie read and write cycles. The 
simplicity oi the design will be evident from the following 
brief description of the read cycle. Just prior to the begin- 
ning of the cycle, the buffered read/write signal BR/VV, the 
buffered upper and lower data strobes (represented in Fig. 3 
as o ne sign al, BDS). and the data transfer acknowledge sig- 
nal DTACK are actively pulled high to ensure their proper 
polarity at the beginning of the cycle, The bus master (the 
entity currently controlling the bus) then defines the mem- 
ory address to be read by driving the address bus, bits BAl 
through BA23, Note that bit RAO is not present on the bus, 
The data bus is 16 bits wide. BAO determines whether the 
upper or lower byte of memory is desired for byte-oriented 
instructions. It is converted by the bus master into the 
appropriate upper and/or lower data strobe, 

After allowing sufficient setup time for the address t the 
bus master asserts the buffered address strobe signal HAS to 
indicate that the address is now valid. All. entities in the 
memory space then decode the address using BAS as an 
enable to determine if they contain the address being ac- 
cessed. The addressed card responds by asserting the M l am 
addressed" signal IMA and holding the DTACK signal 
nonasserted while being accessed. The IMA signal is used 
by the bus expander logic to determine the location of the 
memory participant so that the data bus buffers for the 
expander interface can be turned on if required. Concur- 
rently with asserting BAS, the bus master also asserts the 
appropriate buffered upper and, or lower data strobes to 
indicate which bytes are involved in the data transfer. The 
addressed card can now enable its data bus buffer since it 
knows that it is to be involved in the memory cycle and that 
the data bus direction is correctly defined. For the write 
cycle, the buffered read/write signal is not defined until the 
data strobes occur. Therefore, if BAS alone is used to 
enable the data bus buffers, a bus conflict could result. 

Once the addressed card has placed the data on the bus 
and allowed sufficient setup time, it indicates that the de- 
sired data is now valid on the bus by asserting DTACK. The 
bus master detects the DTACK signal, latches I he data at its 
convenience, and ends the cycle by negating BAS and the 
data strobes. The addressed card detects that the cycle has 
ended by detecting that BAS and or the data strobes have 
gon e away and releases the data bus and cancels the IMA 
and DTACK signals. 

The L'O write cycle is similar. The address and BAS sig- 
nals occur in the same way to start the cycle, All entities in 
the memory space decode the address and the addressed 
card then asserts IMA and holds DTACK in its nonasserted 
state. The bus master then asserts the buffered read/write 
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Fig, 3. Read (a) and write (hi cycle hmtng tor I lO and memory 
cards in the 9826A and 9B36A. 

signal to indicate that a write cycle is in process. Next it 
places the data to be written on the data bus, and after 
sufficient setup time, asserts the upper and/or lower data 
strobes to indicate that the data is valid. The l/Q card 
detects that the data strobes have occurred and stores I he 
data in the proper location. When the storage operation is 
complete, the card asserts DTACK to indicate that the cycle 
can end, The bus master detects that DTACK has occurred 
and removes BAS and the data strobe signals. The I/O card 
then cancels its drive of IMA and DTACK. 

Thus, the programmed I/O protocol is essentially a ver- 
sion of the common asynchronous handshake scheme. The 
addr ess and data strobes provide thesourclng information. 
The DTACK signal provides the response of the receiving 
entity. Since the I/O card may or may not be present, the bus 
cycles are provided with a timeout that automatically ends 
the bus cycle with a bus error trap should an I/O card not 
respond within a specific amount of lime. 

Interrupt I/O 

The interrupt LO scheme provides the ability to interrupt 
the normal instruction execution sequence of the main- 
frame CPU, The B80GT) provides for seven priority levels of 
hardware interrupt. The levels have been distributed 
among the hardware as follows: 
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The internal peripherals have a lower priority than the 
external peripherals for two reasons. First, the human inter- 
face is felt to be secondary in priority to the user's being 
allowed full use pi the mainframe CPU for control pur- 
poses. Second, the design of the &S26A and 9836A is such 
that ihe internal peripherals have drivers thai can be inter- 
rupted without causing improper operation whereas the 
user may have an external device that requires fast interrupt 
response and whose service routine cannot be interrupted 
by internal peripherals. On the high-priority end. the high- 
est interrupt level is reserved for the reset key so that the 
ubqt has full control over the machine. Thus, the external 
I/O cards have four interrupt levels, mure or less by dH.iult. 
This is twice the number of levels available in the 9S25, and 
the external I/O cards do not have to share an interrupt level 
with the internal devices as required in the 9825. Also, the 
setting of the I/O card's interrupt level and select code has 
been divided to allow the user more flexibility in assigning 
the interrupt levels to the :\2 available select codes, 



DMA 

DMA provides the mechanism for high-speed data trans- 
fers between memory and external devices. The 68000 does 
not contain DMA hardware as provided in the I/O controller 
chip of the 9825. A suitable LSI DMA controller was not 
available, so the choice was made to provide a discrete 
DMA controller in the form of an option card. The DMA 
card provides two channels of DMA capability with full 
address range per channel and a maximum buffer size of 
64 K bytes. The card provides a burst mode capability of 
greater than 1.2 million transfers (bytes or words) per sec- 
ond. Actual transfer rates are dependent on the perfor- 
mance of the particular L'O card involved in the transfer. 

Hardware Design 

To get an idea of the simplicity of the interface hardware, 
Fig, 4 shows a functional schematic of a typical L'O inter- 
face, The memory location of the card is defined by the Q 
side of address decoder U7, When BAS occurs the decoder is 
enabled. Its output enables the IMA and the DTACK drivers 
USA and U8B and gate U6A. When the lower data strobe 
BLDS occurs, the output of gate U6A turns on the data bus 
buffer Ul. enables the register decoder LI 5, and starts the 
li tiling delay. The register decoder U5 determines which 
register is involved in the cycle and whether a read or write 
operation is to occur. There are two standard registers that 
all I/O interfaces must provide. The first is a read-only 
register (buffer IJ2 in Fig, 4) which provides a unique iden- 
tifier for the card. By reading this register, the operating 
system can determine which 10 cards are at which select 
codes. The second register, represented by U3 and output 
buffer U4, provides status and control information. A write 
to the register can enable or disable card interrupts. A read 
of the register Indicates which interrupt level the card is on 
and whether or not the card is currently interrupting. De- 
coder U9 connects the card's interrupt request to the ap- 
propriate interrupt level. The second register also deter- 
mines which DMA channel the card is assigned to. The 
DMA interface logic is not shown in Fig, 4. Only four 
low- power Schottky TTL (transistor- transistor logic) IC 
packages are needed to implement the interface for a simple 
DMA timing delay. 
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Low-Cost Printers for the 9826A and 9836A 
Computers 

This family of compatibly packaged thermal printers 
provides quality hard copy of alphanumeric text and 
graphics displays. 

by Michael J. Sproviero 



LIKE ALL COMPUTING SYSTEMS, the 9626A and 
9836A Computer Systems require a companion 
printer. The printer not only has to do alphanumeric 
printing at medium- performance speed and print quality, 
but also must be capable of duplicating graphics displays. 
Secondary needs dictate that the printer be easy to use and 
conveniently located when connected to I he system. As an 
alternative to building the printer mechanism directly into 
the computer, a separate printer package was designed to sit 
on top of the 9826A or 9836A (Fig. 1], 

The thermal print mechanism (also used in HP's 2620 
series of display terminals) uses a printhead containing 15 
thin-film resistors arranged in a vertical column, Characters 
or graphics are printed by moving the head across thermally 
sensitive paper and selectively activating the resistor ele- 
ments at appropriate locations, Characters are formed 
within a high-resolution 18x15 dot matrix to produce 
character quality beyond that previously achieved by ther- 
mal printers. Raster graphics resolution is 90 dots per inch 
both vertically and horizontally and up to 720 dots are 
available across the page. Fifteen raster dot rows are buf- 
fered by the printer before each graphics print line scan, 




Fig. 1 . The HP Model 2673 A Intelligent Graphics Printer is the 
top of the line of HP's 2670 series of thermal printers. Like the 
other printers in this family, it sits conveniently on top of a 
9826 A (as shown above) or 9836 A Computer System to pro- 
vide quality hardcopy of alphanumeric andior graphics data. 



producing high-throughput graphics at lfi,2QU dots/s. Al- 
phanumeric characters are printed b id irecti anally at 120 
characters/s, A microprocessor-controlled algorithm op- 
timizes character throughput. 

The print mechanism is controlled by a microcomputer 
located on an attached printed circuit board. The mi- 
crocomputer accepts and buffers characters, commands, or 
graphics data over a simple 8 -bit parallel interface. Data 
handshake lines are used for interrupt and acknowledg- 
men! of data transfers. Besides accepting input data, the 
microcomputer controls two step motors and the 15- 
element printhead. One motor controls movement of the 
printhead and the other controls paper advance. Phase in- 
formation is maintained by the microcomputer for each 
motor and an on-board timer interrupt is used for speed 
control. A 64K-bit ROM stores the definitions of up to 256 
characters, The microcomputer transforms the ASCII*- 
coded characters to dot information for the printhead. 
Crap hies data is received in row format and transposed to 
column format for the printhead. To achieve 120 
characters /s peak printing speed, the internal timer runs at 
2160 Hz [460-^5 period). With each timer interrupt, the 
microcomputer updates phase information for the step 
motor and outputs dot information to the printhead. The 
printhead resistors are driven from a 16 V power supply and 
energized for 420 jus to print a dot of information, 

Consecutive dots for a given resistor are energized for 
only 16Q jus since the resistor is still at an elevated tempera- 
ture from the previous dot, This technique maintains con- 
sistent intensity of dots and increases resistor life. 

Thermal printing requires contact of the printhead and 
the paper. Appropriate pressure is maintained by a spring- 
loaded guide. To achieve accurate paper advances, the 
printhead is lifted during line feeds. This is done by a 
solenoid which depresses the paper guide spring, relieving 
head pressure and lifting the head slightly. A single Inn 
feed cycle lasts 66 ms. Mechanical time delay for the sol- 
enoid requires 16 ms, 15 motor phase advances take 33 ms, 
and 17 ms is allowed for the head to settle after the solenoid 
is deenergized. Consecutive line feeds are performed with 
the same solenoid cycle and therefore require only an addi- 
tional 33 ms. A photocell is used to sense out-of-paper and 
top'of-form conditions. When using perforated paper, a 
small hole located in the perforation between pages is read 
by the photocell as the paper passes. The microcomputer 
automatically moves the paper past the perforation to the 
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Fig, 2. Configuration menu tor the 2673A This menu is 
printed by the 2673A m the configuration mode. Current set- 
tings are underlined, Each may be changed to any of the other 
settings shown by pressing the appropriate keys on the front 
panel of the 2673A or by program control 

next top-of-forra position. 

Printer Design 

Given a general-purpose thermal printing mechanism, 
the design problems involved overall package and product 
design! including a user control panel, a power supply 
system, a flexible external interface system, and overall 
control logic, The control logic is accomplished by a second 
microprocessor system whose primary function is Interface 
control, da tH buffering, including raster graphics, escape- 
sequence control decoding, printer configuration control, 
and interfacing to the thermal print mechanism. 

As mentioned earlier, the primary product design re- 
is mmpaiiblilitv with the &826A. This in- 
cludes not only industrial design style, but also environ- 
mental and regulatory agency approvals, To do this, suffi- 
cient margin is designed in to guarantee success in all 
system tests. Because the printer sits on top of the CRT 
display of the 9826A or 9836A. adequate shielding of 
magnetic devices $Ui has I he power trans former is required 
to prevent the printer from affecting display quality, Inter- 
nal metallization of the plastic housing and special gasket- 
ing is used to shield the entire enclosure. The results are 
plenty of margin from electrostatic discharge faults and 
certification to FCC Level B for RFI emission with a 10-dB 
margin. 

Printer Family 

A family of printers, including the 2671A Alphanunu-t n 
Printer, 26716 Graphics Printer, and the 2G73A intelligent 
Graphics Printer, is available within this same package, At 
[he top oi the line is tin- 2673 A 1 1 i g 1 1, .i superset ot all I lit- 
features of the other members of the family, in addition to 
the normal print mmle that prints 10 charar tetfi in at 120 
i haracters/s, alphanumeric: characters may be printed at 



16.2 characters in (132 columns per line] or 5 characters in 
{40 columns per line). Print enhancements, such as under- 
lining, framing, and triple-pass bold printing are accessible 
in all three print modes. Ail combinations of these print 
styles can be intermixed in a single line, character-by- 
characler, while still maintaining the high throughput of 
bidirectional printing. Graphics features include autocen- 
tering, windowing, and offsets. Standard page formal fea- 
tures are also available such as margins, tabs, and vertical 
page formatting, Character set flexibility is an advantage of 
the 2673A. European language and genera] -purpose line- 
drawing character sets are available. 

A key contribution of the 2673A is that features are acces- 
sible both prograrnmaticaily through escape-sequence 
commands from the host controller and from the friendly 
front control panel A menu-driven configuration mode 
[Fig. 2] is accessed by four keys on the front panel. The 
configuration mode controls and retains the settings in the 
printer's memory, A state-of-the-art electrically alterable 
read-only memory (EAROM) that can store 128 bytes of data 
is used to remember the state of the machine when the 
power is removed. This novel printer feature allows perma- 
nent user customisation of the printers power-on state. 
Features can be also temporarily invoked by escape- 
sequence commands from the host controller. Thus, fea- 
tures can be turned on and oft without altering the printer's 
memory. 

The 2673A has a multilevel self-test and self-diagnostic 
capability. Separate tests few print capability, data com- 
munications, memory, and I/O can be invoked from a menu 
that is presented when the self-test key is depressed, Any 
faults detected are printed, or if printing is inhibited by 
fault conditions, a hexi decimal LED [light-emitting diode) 
indicator located on the main processor board displays a 
code identifying the fault area. Memory failures can be 
reported to the chip level. 

Interface flexibility is achieved not only in the 2673A, but 
also in I he 2671 A and 2671G, Each interface type has a 
custom printed circuit board that can be changed by the 
user. In addition to the HP-IB interface, which is standard, 
an RS-232-C serial interface and a general-purpose 8-bit 
parallel interface are also available for all printers in the 
family, 
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The 9826A/9836A Language Systems 

by Kathryn Y. Kwinn, Robert M. Haflissy, and Roger E. Ison 



IN EVALUATING A COMPUTER'S software, customers 
are interested in how it can he! p them. Designers want to 
know not only what it does but how it does it, This article 
outlines the capabilities of the three language systems 
[BASIC. IIPL,* and Pascal] available for the HP Model 
9826A and 9836A Computer Systems, explains some of the 
technical challenges that arose in providing these 
capabilities, and describes how those challenges \vere met. 

BASIC 

The BASIC system used in the 982GA and 9B3fiA is a rich 
and powerful language compared to most implementations 
of BASIC. It is patterned after the system used in HP's 9835 
and 9845 Desktop Computers, but it uses a different en- 
hancement strategy. In the 9835 and 9845, the mainframe 
language provides many general-purpose computing 
facilities and is enhanced through the later addition of 
ROMs (re-ad-only memories) to provide selected 
capabilities such as device I/O (input/output)* graphics, and 
structured programming. In the 9826A and 9836A the goal 
is to provide in the initial product all the capabilities re- 
quired to solve a wide variety of instrument control and 
CAD (computer-aided design) problems, and to allow in- 
corporation of new enhancements from time to time, i Jence, 
there are substantial I/O, real-time clock, and graphics 
capabilities in the initial BASIC system. 

This version also provides a number of features that have 
not appeared previously on HP desktop computers. The ON 
KNOB statement can be used to define actions to be taken 
when the knob [rotary pulse generator) Is rotated, Labeled 
COMjTion blocks, which give greater data-sharing flexibil- 
ity, can be defined. The ALLOCATE and DEALLOCATE state- 
ments provide simple (stack discipline) run-time memory 
management Subprograms can have optional parameters. 
Subprogram libraries can be kept in mass storage and 
loaded quickly when needed. Functional HP-IB** nonce n- 
troll er capabilities are also given more emphasis. 

"The language used in tfie HP 9fl25 Desktop Corns..." 

■■Newel". Packard 5 tmptemematfon of IEEE Standard 4B8 (19781 



Customers are interested in execution speed as well as 
language capabilities. They have indicated that far their 
instrument control and computer-aided design problems of 
the 1 980s. they want twice the execution speed of the 982 5 ^ 
The 9826A/983GA BASIC system meets this need, and 
for some applications, exceeds it. For example, some 
I/O operations execute six times as fast as their yH2 5 
counterparts, 

This version of BASIC is not only powerful, it is also easy 
to use as exemplified by its human interface. The knob in 
the upper 1 ef I hand corner of the keyboard can be used in the 
program-edit mode to provide rapid scrolling through the 
program text, an almost addictive feature. As with earlier 
desktop computers, the 982BA and 983tiA have softkeys* 
However, they have the additional capability to associate 
labels with ten of the softkeys and to display them on a 
reserved area of the CRT (cathode-ray tube) display while a 
program is executing. This feature can be used to provide an 
operator interlace in a menu-driven program. Another add i- 
tioo to the human interface becomes apparent when the 
system detects an error, either in parsing or executing a 
program. The error message, instead of just the error 
number, is displayed on the CRT, 

The friendliness and ease of use of 98 2 G A/9836 A BASIC 
is not limited to its human interface, but extends through 
the rest of the language as well, Various enhancements to 
9835/9H45 BASIC that have proved very useful, such as the 
IF,„THENL.ELSE.,.END IF construct, have been incorporated 
in the first release of 9826A/983BA BASIC. Changes were 
made to 9835/9845 BASIC to make it easier to use. The most 
radical changes appear in the I/O sublanguage. 

However, making changes to 983 5/9845 BASIC was dif- 
ficult because of the concern for the iovestment the owners 
of these systems have made in software development, To 
help them convert their current software to 98 2 6 A/983 6A 
BASIC, a translation program is available which can do 
most of the job automatically. It prompts the user for help 
when needed, and also reports complicated situations that 
need to be reworked by hand. 
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Fig, 1 . Map 0/ user RAM for 9826A BASiC language system. 

BASIC: I/O Sublanguage 

From our customers we learned that for instrument con- 
trol and testing applications, they favor the 9825's direct 
approach to L'O over the implicitly buffered approach used 
by the 9835 and U845 Desktop Computers, so we adapted 
9825-style I/O to BASIC syntax. That is, all 9B2GA/9836A 
BASIC device I.'O is under the direct control of the pro- 
grammer instead of being buffered at the system's discre- 
tion. In addition, the I/O language is unified so that the same 
keywords are used to communicate to devices and files. 

The "glue" that unifies the l.'O sublanguage is the ASSIGN 
statement. An ASSKiN statement associates a name and a set 
of attributes with an I/O path. (An example of an attribute is 
FORMAT, whose value specifies whether the data transmit- 
ted is assumed to be encoded in the machine's internal 
representation or in ASCII.*) For greater flexibility, tins 
association is formed a I statement ex® utioa time, not at 
program prerun. Variations of the ASSICNi statement allow 
the programmer to change the attributes associated with a 
defined I/O path or to canoe) the association. 

The resulting I/O sublanguage is much simpler to use 
because of the ASSIGN statement. Only two keywords, OUT- 
PUT and ENTF-:k, are needed to send and receive data. This is 
the case regardless of whether the interaction is with a tile 
or an internal or external device. In the 9835 and 9845, only 
select codes could vary their attributes. In the 9826A and 
9836A, attributes can be associated with files as well. 
Another big advantage of the unified I/O is that it is an 
extremely simple matter to redirect VQ in an one place to 
another. Only the ASSIGN statement must be changed to 
specify the new object and its attributes. Indeed, subpro- 
grams can be written to do I/O without knowing what kind 
of I/O paths they are using, still another advantage to this 
system is its flexibility. New types of I/O paths can be 
supported very easily by extensions to the language. The 
programmer will only need to learn Ixnv tu define I/O path 

"Amflftcan Srantfard Cone for Information interchange 



names for the new types in ASSIGN- statements. ENTER 
and OUTPUT will still be the keywords normally used to 
do the IO. 

Development of 982SA 9836A BASIC 

Man) of the technical challenges that arose as we were 
implementing 9826A/9836A BASIC resulted from the goal 
iking it run twice as fast as HPL on the 9825, The 68000 
used as the CPU (central processing unit] runs at 8 MHz. 
somewhat faster than the 6 MHz achieved by the 9825's 
- uffidently faster to give the desired speed Im- 
provement To complicate matters, ! mA BASK; is 
a much more involved language than HPL, HPL can use a 
fixed- length symbol table because only single-character 
variable names are permitted. In 9826A 9836A BASIC, be- 
cause variable names may be up to 15 characters long, a 
variable-length symbol table is required. This means that 
operand fetches are more complicated. In addition. BASIC 
subprograms have separate environments, whereas III'L 
subprograms share the main program's environment The 
result is that BASIC programs incur significantly more 
overhead whenever a context switch is required. An addi- 
tional slowdown results from the fact that approximately 
80% of the BASIC system was coded in ModcaK** Assem- 
bly language was used only for speed-critical areas such as 
VQ, graphics, and arithmetic and for very low-level opera- 
tions for which Modcal was inadequate. Modcal gave us 
many advantages in reducing the time and effort required to 
develop and debug the system, but as expected, the code 
produced by compiling Modcal is not optimal. 

[he most obvious way to obtain speed would have been 
to write a BASIC compiler rather than an interpreter How- 
ever, several factors favored an interpreter. Interpreters are 
generally easier to write and debug, and the code produced 
by an interpreter is usually much more compact than com- 
piled tude. Thus a customer can solve the same problems 
with less memory, saving the cost ol additional memory. 
Furthermore, mire ustomers have come to expect a friendly, 
to-use program development environment which an 
interpreter can provide. We felt that an interpreter would 
better serve their needs* so we set about producing a fast, 
li i " -rid ly interpreter. 

The lact that the 9826A and 98 36 A have a large, linear 
memory was an enormous help to us in making the systems 
meet their speed goal. It meant that we could assume that 
there would be sufficient memory for program execution 
without resorting tc I J,, k switching or other memory over- 
lay techniques. Fig. 1 shows a simplified map ol user mem- 
ory. A static area for CGMmon occupies the high end. and 
just below tins area is the value area lor the COM variables. 
Next comes the main program's dynamic area, followed by 
a dynamic area for each invocation of every active subpro- 
gram. These dynamic areas form a stack that grows toward 
the low end of memory . At the low end of memory is space 
reserved by the system software intermixed with binary 
programs. Just above this is the static area for the main 
program followed by a stack oi similar static areas for each 
subprogram in the system. This stack grows toward the 
high end of memory. 

I tjy HP's Desktop Computer Otv 9 • 
■ J ascal 
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Each static area for the main program or a subprogram 
consists of a header containing information about the as- 
sociated program block and the layout of the rest of the 
static area. It also contains a symbol table, a token table, the 
internal code, and a dimension table. The static area for 
COM is similar, but contains no internal code, The static 
areas are built at program entry and program p rerun time, 
When the ENTER key is pressed to signify the end of a 
statement, the parser parses the line, builds and partially 
initializes the symbol table, builds the token table, and 
emits internal code in reverse Polish notation (RPN). 

The internal code was designed with both execution 
speed and language expandability in mind. It is sequential 
for simplicity and compactness. Since it contains only rela- 
tive addresses, moving the internal code when it is neces- 
sary to expand the symbol table during program entry does 
not slow the system unduly, All references to program 
variables in the internal code are given as indexes into the 
appropriate symbol table, This helps execution speed by 
eliminating symbol table searches. The system does not 
retain the actual source line T but can recreate it by means of 
a backlister, When the RUN key is pressed or the RUN com- 
mand is executed, the system performs a prerun on the 
entire program. During this prerun phase, each static area 
is completed. The header and symbol table are filled in 
and a dimension table containing the declared dimensions 
of every array is built. The COM value area is also created, 
the structured programming statements are statically 
matched [e.g., each FOR statement is associated with ex- 
actly one NEXT statement), and the internal code is modi- 
fied to include the branching addresses associated with 
these constructs. After the prerun, the system uses a table- 
driven interpreter to execute the internal code, 

When execution begins, a dynamic area for the main 
program is created immediately below the COM value area, 
and the interpreter begins executing the main program's 
internal code. Another dynamic area is created on top of I lie 
dynamic stack each time a subprogram is invoked. Each 
dynamic area contains a complete current environment for 
either the main program or a subprogram invocation 
(982 6 A/98 3 6A BASIC is recursive] and includes a call 
block, pointers to parameters, a copy of the dimension table, 
the execution header, storage tor the values associated with 
FOR loops, and the value area for statically and implicitly 
declared local variables. The size of this portion of the 
dynamic area is known at subprogram invocation. It is 
pushed onto the dynamic stack and parts of it are initialized 
at this time. The dynamic area also contains storage for 
variables created in ALLOCATE statements, for the control 
blocks associated with event-initiated branching state- 
ments (ONs), and for a GOSUB return stack. It also has room 
for temporary structures used during statement execution 
and for expression evaluation, These areas are created and 
destroyed as necessary during execution, but always ac- 
cording to a strict stack management discipline. 

Certainly some of the data structures and operations de- 
scribed above sound more complicated than necessary. The 
reason for introducing these complications is to obtain 
greater execution speed. The speed penalties associated 
with a variable- length symbol table are partially overcome 
by making each symbol table entry the same length. Thus 



each symbol table is an array of records and can be accessed 
efficiently by the interpreter, To make fixed-length symbol 
table entries possible neither the identifier names nor their 
values are kept in this table. The names are stored in a 
separate token table in the static area, and each symbol table 
entry contains an index into the token table. Token table 
entries are variable in length, and hence the token table 
must be searched whenever it is accessed. However, the 
token table is used only during parsing and when it is 
necessary to recreate the program source (e.g., for listing the 
program), so it is nut important that access be fast. The 
values are stored in the dynamic area at the high end of 
memory, just below the COM static area. Values are rep- 
resented in the symbol table by an offset from the base 
address of the dynamic area. These offsets are determined 
and stored in the symbol table during program prerun, 
along with the size of the value area. Hence, at subprogram 
invocation time, the value area can be pushed onto the 
dynamic stack very quickly. 

Several language restrictions were necessary to imple- 
ment the system as described. It is not possible to edit a 
program without stopping it. Furthermore, statements that 
are to be executed directly (Le,, are not part of a program) 
may not introduce new variables. SUBroutine and DEFine 
FunctioN statements can only be appended to the end of the 
program, not inserted randomly in I he code. Similarly t to 
delete a SUB or DEF FN statement, the entire subprogram 
must be deleted in the same operation. Declaratory slate- 
ments such as INTEGER are processed at program prerun 
and hence must use constants rather than numeric expres- 
sions to specify array bounds and string lengths. ALLO- 
CATE, on the other hand, is processed during program 
execution and may contain expressions. Because structured 
programming statements are statically matched at prerun. 
programs that attempt to abuse these structures [e,g, t by 
branching back and Ibrth between FOR loops) will not pro- 
duce the expected results, 

Execution speed was also enhanced by doing binary 
arithmetic instead of binary-coded-decimal [BCD). The 
9825 uses BCD representations of numeric data, but the 
9826A and 9636A usetwoVcomplement representation for 
integers and the proposed IEEE 64-bit floating- point stan- 
dard formal for real numbers. In this way, w r e are able to take 
advantage of the 6HO00 microprocessor's built-in instruc- 
tions for integer arithmetic, Lfsing binary arithmetic has 
several advantages in addition to speed. First, binary com- 
putations lend themselves to easier error analysis. In addi- 
tion, binary representation is much more compact so that 
for the same amount of storage space — 64 bits per real 
number — we are able to get 15 decimal digits of precision 
versus 12 digits in the 9825 and are also able to support a 
much larger range of exponents. 

Another way in which the 9826A/9836A BASIC system 
met its speed goal w r as reducing the interpreter's end-of- 
line overhead. There are many conditions that must be 
tested after each line is executed (e.g,, is trace output re- 
quired, is there any event-initiated branch that should be 
serviced, and is there a statement waiting for direct execu- 
tion?). In all, some twenty or more tests can be performed at 
the end of every line. Rather than perform all of these tests 
for each line, we introduced a master bit that is set 
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whenever any of these conditions becomes true. The master 
bit is always checked at the end of a line. If it is false (which 
is normally the case), no further tests need to be performed. 
Only if it is true does the system do exhaustive testing to 
determine the required actions. 

The Large memory in the 9826A and 9836A allows the 
interpreter to run faster because sla low is highly 

unlikely. A block of memory that is large enough to allow 
the evaluation of a worst-case normal numeric expression is 
reserved at the end of the static area. The dynamic stack is 
not allowed to grow into this area unless the system is 
evaluating an expression. Operations such as subprogram 
invocation that require a large block on the dynamic stack 
do an overflow check* but most operations do not need to 
make this test. 

Because the 98 26 A and 9836A are designed to be HP's 
premier HP-IB instrument controllers, I/O speed is of 
paramount importance. For this reason* most of the I/O 
system was written in assembly language. The strategy 
used by t he I. O system is much the same as the strategy used 
to expedite subprogram invocation- namely doing as many 
operations as possible before the actual data transfer be^ ins. 
The speed optimization begins at system power-up. At this 
time, the system initiaJizes a select code table that records 
such information as whether or not an interface is in use, the 
type of interface, and the location of the appropriate I/O 
drivers, Individual I/O statements consult this table rather 
than determine the necessary information on their own. 

Each I/O operation is divided into three phases; initializa- 
tion, data transfer, and termination, The initialization 
phase increases speed by minimizing the per -byte overhead 
associated with data transfer. During initialization, the in- 
terpreter determines the source or destination of the data 
transfer, what 10 driver is to be used, and whether the data 
be encoded in Interna] form or in ASCII. Ibis informa- 
tion is stored away in a temporary table on the dynamic 
stack where the system can refer to it for the duration of the 
statement's execution. Certain procedure variables (vari- 
ables whose values are procedure names) that will be used 
to accomplish the data transfer get values at this time. The 
I/O driver also checks validity during initialization. For 
devil e I O* the dri ver determines that the specified interface 
does indeed exist and that the source or destination address 
is valid and then addresses the bus. For files, the driver 
locates the place on the storage medium where the opera- 
ndi is lo bcftin. 

BASIC Enhancements 

Language enhancements can take on two forms: adding 
totally new statements or adding new syntax and semantics 
to existing keywords- Hither kind of enhancement can be 
difficult to implement unless the svstem has been designed 
Eoi expandability, 

Part of the solution to the expandability problem involves 
both the parsing strategy and the design of the internal code 
generated by the parser, 9826Au81U>A BASIC parses a pro- 
gram statement whenever the ENTER key is pressed, Ji 
parses statements entered from the keyboard when the 
EXECUTE key is pressed. In either rjase, "I I horn are syntax 
errors, ihev are reported and no further action is taken. Of 
course, a given line might be erroneous il some enhance- 



ment is absent, but perfectly correct if that enhancement is 
part of the system. To allow such lines to be parsed prop- 
erly, we adopted the following strategy. The initial 98 26 A. 
98 36 A BASIC system has its own syntax module, and so 
does each of the enhancements. The parser for the initial 
model of the 9826 A or 983 6 A always begins the parsing 
process. If it does not recognize a token J t does not report an 
error immediately* but first polls each enhancement's 
parser to see if any of them can handle the token in question, 
If any of the enhancements does recognize the mysterious 
token, it parses it, generates the appropriate escape se- 
quence and internal code, and then returns control to the 
main parser. Only when none of the parsers can deal with 
the token is a syntax error generated. 

To understand how the enhancements are processed at 

ttion time, it is necessary to understand the design of 
the RPN internal code generated by the parser, At execution 
time, this internal code is processed by a table-driven in- 
terpreter. Each operand is represented by an index into the 
appropriate symbol table array. (Opcodes 1 through 127 are 
reserved for operands. The first one hundred are simple 
indexes. The remainder are used on first byte of a 

two-byte encoding of a symbol table index. Using this 
scheme, each symbol table can accommodate approxi- 
mately 7000 entries.) Each operator is represented by one to 
three bytes. To maximize both execution speed and code 
compactness, single-byte op codes are assigned to the more 
frequently used operators and two-byte op codes to the less 
Frequently used operators. A single-byte op code is an index 
late ihe primary interpreter table. The first byte of a two- 
byte op code sequence identifies a secondary interpreter 
table, and the second byte is an index into that table. A 
three-byte op code is always associated with an operator 
supported by a language enhancement. The first byte Iden- 
tifies the op code as a three-byte sequence, the second byte 
identifies the enhancement that supports I In- operator, and 
the third byte is an index into the enhancemenTs interpreter 
table. 

The scheme outlined above solves many, but not all, oi 
the language enhant emenl problems. It works well foradd- 
ing totally new statements to the language, but it often 
breaks down when an existing statement is enhanced. As an 
example, consider file I O. The only mass memory device 
supported by BASK; in the initial model ol the 98 26 A is the 
internal flexible disc drive, but the first set of enhancements 
allows use of the HP 9895 flexible disc drive as well. The 
process of writing data to a tile on the 989S is totally differ- 
ent from writing to a file on the 982tiA\s internal flexible 
disc unit* yet the programmer uses the same statement for 
either operation* In the past, problems like this were often 
solved by making the enhancement ROM support both the 
old and the new capability. This strategy is fraught with 
problems, not the least of whirl] is that after several en- 
hancements the system may contain multiple versions of 
code to do (supposedly] the same thing, and all but one 
version will he ignored, We were determined to avoid this 
situation whenever possible. To do so* we devised anetabo- 
rate system of "hooks," In many cases, hooks consist oi 
procedure variables in the implementation code. The action 
taken at a given time depends on the procedure name that is 

due of the variable when it is encountered. Such li 
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are incorporated in the system everywhere extensions can 
be reasonably anticipated. So far. they have proved very 
effective in eliminating code duplication. 

Since the 98 26 A and 98 36 A put such a strong emphasis 
on I'O. this is one area in which many enhancements were 
anticipated. The hooks in the I/O implementation are thus 
extremely important. As mentioned in the discussion of I/O 
speed, each I/O operation is divided into three phases: in- 
itialization, data transfer, and termination. Each of these 
phases is further divided into an object-independent and an 
object-dependent [I/O driver] portion. The object- 
independent code performs all manipulations that are in- 
dependent of the source or destination of the I/O, Among 
these are data conversion and formatting. The object- 
dependent code performs the rest of the operation and is 
tailored to a particular source or destination. There is a 
standard interface between the object- independent and 
object- dependent routines. By using procedure- variable 
hooks at this junction, it is relatively simple to support new 
hardware interfaces by adding only 1'0 drivers. The beauty 
of this approach is that such additions are transparent to the 
programmer, 

HPL 

The use of HPL began in February a I 19,72 with the intro- 
duction of HP T s 9820 Programmable Calculator 1 By the 
time the 982 5 A- was introduced in |anuary 1976, HPL had 
evolved into a sophisticated programming and I'O control 
language, Today, there are over 28,000 9825 systems in- 
stalled worldwide, proving that HPL has made a home for 
its etc 

While the 9825 and its language have become popular 
with HPs customers, HPL is nut a current-technology lan- 
guage; there is no real structured programming capability. 
Variables are single letters, not multicharacter. It is cryptic 
and often hard to read, Parameters and local variables tor 
functions and subroutines are limited to simple numerics. 
So one might justifiably ask the question, "Why would 
Hewlett-Packard implement II PL on another machine 
when BASIC and Pascal are belter choices?' n 

The answer lies in the recognition that the cost of 
software is continually increasing while the price/ 
performance ratio for hardware has been plunging down- 
ward. Computer users are looking for ways to increase per- 
form ance by moving to new hardware without having to 
discard their previous investment in software. 

The overriding goal of the HPL project For the 9826A and 
9836 A was to provide a way for 98 2 5 u.sers to run their 
existing software on new -technology hardware. The key 
strategies for achieving this goal were to maintain a simiiar 
internal architecture by translating 982 5 system code to 
68000 code and to place 9825 compatibility as the highest 
priority of that translation process. As will be seen 
shortly, even some performance is sacrificed to maintain 
compatibility. 

The second objective of the project was to add language 
enhancements that would either complement the new 
hardware available in the 98 26 A and 9836 A or fill in known 
deficiencies in the language. The knob, alphanumeric and 
graphic CRT displays, large read-write memory, built-in 
flexible disc drive, programmable beeper, powerfail, and 



real-time clock are exan 1 1 \ I es i I hardware features for which 
HPL language extensions were desired. 

Development of 9826A/9830A HPL 

The design team had to address four major challenges to 
meet the objectives: human interface, mass storage, I/O. and 
mathematics. 

In the area of human interface, much of the 982 5 's edit i ng 
and operator I/O was designed around a 32-character, 
single-line display and a 16-chaxaeter strip printer. One of 
the major enhancements of 9826A/9836A HPL is the im- 
plementation of multiline editing aod a scrolling "soft 
printer" on the CRT. For the scrolling printer, the number of 
pages of information thai can he maintained off- screen can 
be programmed from a minimum of two pages to as many as 
the available read/write memory can hold. Also, the 9825 
definition of special-function keys is extended on tin 
9 826A and 98 3 6 A to allow labels to be displayed on the CRT 
and to allow the keys to be individually definable from a 
running program. 

Another important hardware feature available on the 
9826A and 9B36A is CRT graphics. The HPL system has 
been extended so that plotter commands that on the 9825 
were always directed to an external plotter can now be 
directed to the graphics screen. Some new statements 
necessary for CRT graphics were also implemented. 

The mass storage system is an area where creative solu- 
tions have a 1 lowed the 9826 A and 9636 A to be compatible 
with the 9825, yet still provide a real performance contribu- 
tion. The 8825 has I wo distincl mass storage systems: tape 
and disc. The internal tape cartridge uses a nondireclory, 
file-by- number system and is accessed by a set of statements 
j m Impendent of (he directory-based, file-by-name disc sys- 
tem. It was necessary to implement both systems, but how 
could it be done on only one device? The disc system was 
the most natural fit with I lie built-in flexible disc drive, but 
what could be done with the tape statements? 

The solution to the dilemma was simultaneously map- 
ping tape file numbers into disc file names and tape state- 
ments to disc statements. Consider, for example, a tape 
statement such as rci 5 which would be used to record the 
current program onto tape file 5 of the current tape track, 
say track 1. In the 9826A and 9836A. such a statement 
will cause the program to be saved onto disc file T1F005. 
Thus all actions dictated by tape statements are emulated 
on the disc. 

Another key feature of the 9 8 28 A/98 36 A HPL mass 
storage system is the unified approach to all devices. The 
same tape or disc statements can be used to access several 
devices j internal flexible disc, or external 9885. 9895, HI :i4, 
8291)1, 82902), The 9134, 9883. and 9895 support two 
different formats: one compatible with the 9825, 9835, and 
9845 computers and the other. HP LIT (logical interchange 
format), compatible with 9826A/9836A BASIC and Pascal. 

One of the major uses of the 9825 is as an 10 controller, 
and a majority of HPL software uses direct I/O card register 
access. However, the I/O interfaces of the 9826A and 9836A 
are of completely new design and the card registers R4 
through R7 no longer exist To provide compatibility with 
existing HPL programs, the 982BA/983GA IIPL system pro- 
vides a software emulation of the 9825 I/O cards. Internal 1 v. 
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BCD Arithmetic on the 68000 



The main objectives tn wntsng the 9826A/9836A HPL arithmetic 
routines were 1 00% cc-mpa" L B25 and performance 

that met or exceeded that of the 9825 Because of major an 
iuraJ differences between the two processors, a switch to binary 
arithmetic was considered early *n the project The BPC 
processor chip) used m the 9825 has two ftoating-point ac- 
cumulators and ten instructions for manipulating 12-digrt SCO 
numbers. f On the other hand the 68000 CPU has onfy three BCD 
ristructions {add, subtract, and tens complement), 
and these operate on only two BCD digrts at a time 

Most of The HPL language system was translated from BPC 
assembly language to 68000 assembly language However, this 
was impractical for the arithmetic routines because of the high use 
of custom BPC math instructions As a result, the arithmetic 
routines were written from scratch using the 9825 only as a. defini- 
tion of what each operation should do. Speed was obtained by 
apply jng a number of programming techniques 
1 . Heavy use was made of in-line code instead of subroutines and 

(oops. 

2 Conditional branches were organized to minimize the execu- 
tion time of the most commonly taken path 

3 Instructions and addressing modes were carefully selected to 
minimize execution time. 

4. The multiply and divide operations were tmplemented using 
base 1 0000 With this technique, BCD numbers are converted 
to base 10000, the base 100OO numbers are multiplied or 



Original Number Formats 



12-Dlgit Mantissa 
(4 Bits Per BCD Digit) 



Ms 0, Dt D 3 0, DJ D* 0, D 6 D 9 D„ 



v 



Mantissa Sign * D. 9 



32 



Base 10000 Formal: 



Exponent 



3-Digit Base- 10000 Mantissa 
(16 Bits Per Base- 10000 Digit) 

Fig. 1. Conversion of BCD number format to base-10000 
format 




_ied using the binary multiply and divide instructions of the 

68000. and the result is converted back to BCD 
5 Execute multiply and divide operations were further 

reduced by providing special routines for handling numbers 
e significant digits 

Each of these techniques proved useful in reducing the execu- 
tion time of arithmetic operations However, the resulting 60000 
code is several times larger than its BPC counterpart— a small 
price to pay for the added performance 

Of special interest is the use of base 1 0000 to speed up the 
multiply and divide operations This technique works as follows. 
the 12-digit BCD mantissa is convened to a three-digit 
base- 10000 mantissa (see Fig 1). Each base- 10000 digit repre- 
sents four BCD digits, and is stored as a 16-bit binary number 
Next, the binary multiply and divide instructions of the 68000 are 
used to perform a multiple-precision operation on the three 
base- 10000 digits. The base-10000 result ts converted back to 
BCD. after which rounding and normalization operations are per- 
formed The conversion to and from base 10000 involves a com- 
bination of table lookup and arithmetic operations Note that she 
base- 10000 representation is only an intermediate step m the 
floating-point multiply and divide operations Floating-point num- 
bers on the 9326A/9836A HPL language system are stored in the 
same BCD format as In the 9825. 

It may seem that the multiply and divide operations are fairly 
complex, and they are However, the execution time for the entire 
operation (including conversion to and from base 10000) is one- 
half to one-third that of the 9825, Because a similar technique 
could not be found for the floating-point addition and subtraction 
routines, these operations execute at approximately the same 
speed as their 9825 counterparts 

Once the arithmetic routines were complete, their operation 
had to be verified against the 9825 for 100% compatibility, This 
was done by connecting a 9825 and a 9826 A back-to-back via the 
HP- IB and running millions of operands through the routines and 
comparing the results. The final routines ran for several days 
without finding any discrepancies, On the 982 6A, even the ran- 
dom number function produces exactly [he same values as the 
9825 

-Andy Goris 
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each 9H26A/9836A VO card driver maintains sufficient state 
information to construct responses to card register accesses 
that will match what a 9825 system would have obtained. 
The fourth major challenge area For the project was I he 
mathematical calculations. The 9825 system uses BCD [bi- 
nary coded decimal) representations of numbers along with 
special processor instruct inns to operate on BCD values. 
The 60000 CFH 1 lends itself to binary representations better 
than to WCD. and has very little processor support far BCD 
operations at all, Since compatibility was the number 0B8 
objective, BCD representation pi numbers has been main- 
tained in the 9&28A/9836A HPL system. However, a special 
base-lQOGG mathematics package is Implemented Inter- 
nally to lake advantage ol the multiply and divide insti na- 
tions of the 68000 ( H I which operate on binarj numbers). 



See the box on this page for more details on this conversion 
to base-10000 arithmetic. 

If oompatibij ity with the 9825 was the primary objective, 
it is reasonable to measure the success of the project by bow 
easy it is to run 9B25 programs on a 98 26 A or UfOGA. The 
results of running many real applications indicate that 
many 9825 HPL programs run wit hoi il mod ill cat ion, There 
are* however, certain 9825 machine characteristics that 
were impossible to duplicate on the U82f>A and 9836 A, and 
so there will be some programs that require minor changes. 
The incompatibility ■ <l to the following areas; 

■ I/O cards — some low-level control could not be emulated 

exactly because of new hardware design, 
• Binary and memory Tiles — because of the new processor 

and changes in internal data structures, files contain 
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binary programs and memory images are not compatible 
m Memory use — some data structures now require more 
read/write memory. However, this is rarely a problem 
since the basic 9826 A or 98 36 A Computer System has 
more memory than a 9825, 

■ Real-time clock (RTC)— the 9826A and 983GA support 
special mnemonics to access the internal RTC Instead Of 
the I/O statements used on the 9825 to access an external 
RTC. 

■ Keycodes — the hardware keycodes on the 9825 and the 
98 26 A and 9B36A are different, although a simple sub- 
routine (included with the system] translates the new 
codes into the old codes for programs that expect the 
latter, 

Unlike the incompatibility list, the enhancement list is 
quite long. Some of the enhancements are new uses of 
existing mnemonics while others are new mnemonics. 

■ CRT/Graphics; multiline editor, independent enable of 
the display of alphanumerics (text], key labels, and 
graphics, separate display areas for program and 
keyboard-executed display statements, full graphics 
support including binary plot, pointer, and graphics 
load/store, alphanumeric and graphics dump, and read/ 
write alphanumeric text from any area of the display. 

-. Keyboard; full international keyboard support, program 
interrupt from knob, programmatic definition of soft keys 
and their labels, ability to push rinv key from a program or 
softkey, and ten-deep recall stack. 

• Real-time clock: time-of-day clock and program inter- 
rupts based on time match, time delay, or cycle, 

■ I/O: read and write access to buffer pointers, ability to 
abort an active transfer, ability to set EOI (end or identify] 
on the last byte of an H! J -1B transfer, access to two chan- 
nels of DMA (direct memory access) and use of DMA with 
in MB, "printer is" 1 command for setting the default 
printer device, and cancelling of un-interrupt branches, 

■ Mass storage: tape emulation on disc, "mass storage is" 
command for setting the default mass storage device, and 
unified mass storage commands. 

■ Powerful (if installed; this is a hardware battery backup 
option lo be available in the near future): a program 
interrupt can be enabled In the event that power is re- 
moved for more than a specified time, allowing for 
checkpointing or other corrective action. 

z Miscellaneous: 32 user flags, string/numeric conversion 
to any base, read, data, and restore operations for pro- 
gram constants, and access to the programmable beeper. 

Pascal 

Pascal on the 9B26A and 9836A combines the appeal of a 
modern, well structured and widely accepted pro- 
gramming language with the computing power of compiled 
code and a state-of-the-art microprocessor. The product is 
both an easy-to-use Pascal programming environment and 
a complete system development toolbox for the 98 26 A and 
9836 A. Lin like previous HP desktop computer products, 
this software system gives programmers direct and com- 
plete access to all the hardware resources built into the 
9tt2fiA and 9836A mainframes. 

Earlier in this article it was mentioned that the BASIC 
language system is largely written in Modcal, a program- 



ming language used internally at HP's Desktop Computer 
Division. Modcal consists of the HP standard Pascal lan- 
guage and some extensions for system programming. Many 
of the extensions were derived from the Modula language 
designed by N. Wirth. 3 

The software tools used to develop BASIC were also writ- 
ten in ModcaL and although they did not originally run on 
the 9826A T they were adapted to it for improved perfor- 
mance when prototype hardware became available, This 
process involved com pi 1 ing the programs into native 68000 
code, and designing and implementing an I/O subsystem, 
The 9826A became its own development environment, 
with a compiler producing native code t an assembler, a 
linker, and some other utilities. 

These tools have been developed into production-quality 
software offering these features: 
* The user-friendliness HP's products are known for 

■ A modern, highly structured programming language 

■ Assembly language for people who want it 

■ Complete access to all hardware resources with 
minimum system interference 

■ Very fast program turnaround, with immediate execu- 
tion after compiling 

■ Execution speeds close to the limits of hardware perfor- 
mance 

■ Demand linking and loading (no explicit user action 
needed) 

■ Effective use and management of compiled code module 
libraries 

■ Debugging lo the register level if necessary 

u Smooth transition between normal execution and de- 
bugging modes 
» Full use of the 16-megabyte address space of the 68000 
CPU, including use of memory as a very-high-perfor- 
mance mass storage medium 
m System easily tailored to have a new personality defined 
by the programmer. 

Unlike BASIC and HPL in which the entire language 
system is always resident in read/ write or read-only mem- 
ory, the 9826A/9836A Pascal environment is broken into 
subsystems which are loaded from mass storage when 
needed, The most important components are: 

■ Linking loader and file system 

■ Command inl^rpreter 

■ Debugger 

HP standard Pascal compiler 
« 68000 assembler 

■ File manager 

■ Screen-oriented editor 

■ Librarian 

The system presents itself as a hierarchy, with the com- 
mand interpreter at the top and the compiler, editor, file 
manager, assembler, and librarian as subsystems. At each 
level in the hierarchy the user is prompted with a menu of 
commands. A command is typically a single keystroke. For 
instance, at the highest level the system prompts: 

Command: Cmplr Edit File I nit Libr Run Xcut Ver 

Typing C invokes the compiler, E or EDIT calls up the 
editor* F brings in the file manager, and so on* Each subsys- 
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tern Ln turn always prompts with its own list of capabilities. 

The program development sequence is very simple. The 
editor is used to build or modify a source program, which is 
saved in a file in memory or on mass storage. The user 
presses the HUN key. If the compiler notices a syntax error, 
the editor can be invoked: it will place the cursor at the 
point where the error was detected. If there are no syntax 
errors, the program will immediately be loaded and begin 
execution. Subsequent RUN commands will not recompile 
the program unless the editor has been used to modify it. 

The editor is an in- memory, screen -oriented design (no 
line numbers ). It can edit as much text as the computer can 
store in its memory. It has complete search-and-replace 
capability, and can run in either program mode or 
documentation mode. Portions of text can be moved or 
copied. Full, smooth scrolling access to the entire edit file is 
provided by the knob on the keyboard. 

The compiler normally accepts HP standard Pascal, con- 
forming to the corporate standard, It can also restrict pro- 
grams to ISO Pascal, reporting any violations of the pro- 
posed international language standard. It can also on request 
accept most of the language extensions of UCSD Pascal [a 
trademark of the Regents of the University of California), so 
programs written in that language will transport easily. 
Finally, it can be told to accept eight system programming 
extensions chosen from DCD's internal Modcal language. 
These extensions are necessary to provide error trapping 
and full access to the 9826A/9836A hardware set. 

Compilation is a one-pass process which translates pro- 
grams into an internal tree representation from which code 
is generated. The output is relocatable object code, ready to 
run. Compilation speeds exceed 4000 lines per minute 
when the source and object files are stored in memory, 

The I wo- pass assembler accepts 68000 instruction 
mnemonics in the syntax defined by the manufacturer, and 
produces object code in the same formal as the compiler. 
Either absolute or relocatable assemblies are possible. As- 
sembly speeds are up to 40(H) lines per minute, 

The debugger allows stepping through an executing 
program one line at a time, or one machine instruction at a 
lime* As I he program executes, the line numbers can be 
iayed at the lower right corner of the screen. A history 
queue can be kept of the last 63 line numbers or instruction 
addresses executed, so it's possible to see how the program 
arrived at the point where an error happened. Errors can be 
trapped before the program is aborted, and the entire state of 
the CPl ' registers as well as all of memory is accessible at 
any time while a program runs, The debugger maintains its 
own screen and human interface, so the normal user screen 
content is not disturbed by debugging action. 

Up to 50 logical devices can be on-line at once. Many 
logical devices and their directories can be on a single large 
mass storage device, The file manager can create and 
examine directories, copy, purge, or rename files, and back 
up entire logical devices. 

9826AJ9836A Pascal defines a method by which incom- 
plete portions of a program, called modules, may be corn- 
piled without reference to any program that may ultimately 
use them. A module, even after being compiled, carries 
with it the precise specification of how it must be interfaced 
to any other program or module. 



A library is simply a file containing programs or modules 
of code. The output of the compiler, assembler, and libra- 
rian is always a library. A program using precompiled 
modules simply specifies that they are to be imported from 
some library: thereafter, the compiler and linking 
mechanisms automatically bind the module into the pro- 
gram. Libraries may be resident in memory or found in mass 
storage. 

The librarian provides three library management 
capabilities: [inking, constructing libraries, and disas- 
sembling libraries. Ordinarily, linking occurs without in- 
tervention when a program is run. The librarian's explicit 
linking function is mainly for use in generating an entirely 
new system. Constructing a library is simply the process of 
collecting modules of code into a group so they can be 
conveniently managed together, To disassemble a library is 
to examine any or all of its modules in detail — the interface 
specifications, linkage information, and even machine code 
can be displayed on demand, 

A standard library is supplied with the system. It contains 
modules with about 150 procedures to perform device HO. 
interactive graphics, and disc file interchange with many 
other HP computer systems. These library routines can be 
used by any Pascal application program. 

Direct I/O to peripheral devices is supported in four 
different transfer modes over HP- IB. RS-232-C. and 16-bit 
parallel interfaces. Fas! handshake transfers are done in a 
very tight loop, with the 68000 CPU devoting full attention 
to processing each byte or word of data as quickly as possi- 
ble, Interrupt mode allows the CPU to initiate a transfer, 
then go on to other work. Whenever the peripheral device is 
ready to transfer a unit of data, it interrupts the CPU with a 
request. Burst transfer is a combination mode, initiated by a 
peripheral interrupt and completed in a fast handshake 
loop. The fourth transfer mode uses a vdty high-speed DMA 
controller, instead of the CPU. to service data requests, 
DMA transfers are normally overlapped with other compu- 
tation by the CPU. 

The graphics routines, which will be familiar to some 
readers as a subset of the DGL graphics library available on 
W 1000 Computers, produce two-dimensional drawings 
suitable tor many design and engineering applications. 
Graphical output can be sent to the built-in display, to 
external color monitors, and to a variety of plotters, Line 
drawing is very fast — about 2500 6-ram vectors per second 
can be drawn on the built-in display. Input can be taken 
from the knob on the keyboard or a digitizing tablet. 

There is no distinction between user and system pro- 
grams. In fact the command interpreter is a relatively sim- 
ple program that allows the user to execute other programs 
or subsystems, and to catch and report errors. It's easy to 
replace the command interpreter w ith any other program, 
resulting in a system that can only do what the substitute 
program knows how to do. 

The Unking loader and file system form the kernel of the 
system, the only part that has to be present for a single 
Pascal program to run. The loader IS able to bring both 
programs and modules into memory, It also remembers 
what is in memory. This means that modules can bs loaded 
once, then used over and over by subsequent programs. 
This feature can he used to extend or override system 
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capabilities. Programs can also be loaded and retained in 
memory, to be called whenever they're wanted. When this 
is done, they are immediately executable. Mo later accesses 
to mass storage are required. 

The operating system, consisting of the file system, I/O 
drivers, linking loader, and command interpreter, is a set of 
memory- resident libraries, most of which are written in 
Pascal, This means that the services provided can be called 
on by programs or other modules. Moreover, a programmer 
can construct custom modules that extend the capabilities 
of the system. Such extension modules are bound into (hr> 
system simply by loading them, and there is an easy way to 
cause them to be loaded automatically when the computer 
is turned on. 

The system can also be tailored by removing capabilities. 
All of the components mentioned above, except the linking 
loader and file support package, can be removed or replaced 
by ihe user in a few moments. 
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Data Communications for the 9826A 
and 9836A Computer Systems 



by Carl M. Dierschow and Robert P. Uhlrich 



AS COMPUTERS become more common throughout 
the world, the need to exchange data between them 
also increases, Data communications is no longer a 
luxury; it is a necessity. The HP Model 98628A Data 
Communications Card provides this communication path 
for the 9826A and 98 36 A Computer Systems. 

The 98628A card is a newly developed serial data com- 
munications interface for the 9826A and 98;i6A + It handles 
many asynchronous protocols and the Hewlett-Packard 
Distributed Systems Network/Data Link (DSW/DL) protocol. 
This interface fits well into terminal emulation applications 
because it is able to handle many dialects of asynchronous 
communications including half duplex, full duplex, and 
enquire/ acknowledge or start/stop handshakes, as well as 
automatic detection of end-of-Hne and prompt- character 
sequences. It is also able to drive a variety of RS-232-C 
peripherals. 

The data link protocol serviced by this card is tailored for 
data gathering applications in which an HP 1000 or HP 
3000 Computer controls the operation of a factory floor. The 
protocol is handled automatically lor I he user, including 
blocking and full data transparency. 

The 9B628A is supported by the BASIC and Pascal lan- 
guages used in the 9826A and 9836A. It uses the same I/O 
statements as other interfaces for these systems. 

The 98628A contains three i ndependent data and address 
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Fig. 1 . Block diagram of HP Model 98628 A Data Communica- 
tions Card. 



buses: the mainframe, internal Z80 and shared buses (see 
Fig, 1). The mainframe bus provides a direct connection to 
the 68000 microprocessor's memory bus. The internal Z80 
bus connects the 'AdO microprocessor, timer, serial I/O 
(input/output) chip and program ROM (read -only men « 
The RAM (random-access memory] and hardware registers 
are connected to both the Z80 and the 68000 by the shared 
memory bus. All interaction between the 68000 and the 
card's Z8Q is performed through the RAM and registers on 
this bus. 

Mainframe Interface 

The 98628A card contains a 2K~byte static RAM which is 
used to implement a powerful data communication inter- 
face to the 9826 A and 9836A mainframes. H is shared be- 
tween the processors in the mainframe and the 986 2 6A 
card, meaning that both axe allowed to read from and write 
Ui I he memory. The arbiter ensures that both processors are 
not allowed to access the memory simultaneously, This 
shared memory fits well with the system processor which 
performs all of its I/O via a memory-mapping mechanism 
allocating 64K bytes to each I/O card. 

The shared memory contains receive and transmit buf- 
fers. Both are implemented as dual circular buffers. One 
buffer of the pair is reserved for control information, while 
the other contains only data characters, A hardware 
semaphore protects access to critical pointers in this shared 
buffer scheme. 

To satisfy some of the special mainframe I/O require- 
ments, three special memory addresses are implemented in 
discrete hardware, and the first rwo locations of the shared 
RAM are supplemented with additional hardware, These 
special additions supply: 

■ A constant ID register, which uniquely identifies this 
type of card 

■ A mechanism whereby the card can interrupt the main- 
frame processor 

■ A mechanism whereby the mainframe can interrupt the 
card's processor 

■ A hardware semaphore that is used by the firmware to 
control access to critical resources In the shared memory 
for short periods of time. 

The card -to- mainframe interrupt mechanism is able to 
communicate several different Interrupts : received data 
available, transmit buffer space available, error, and an inter- 
rupt condition specified by the user language, 

The mainframe-to-card interrupt mechanism communi- 
cates high-priority commands from the user to the card. 
Several other commands thai are not used by the 9K628A 
aresenl via this mechanism by the system's drivers, but the 
< mil rejects thestf us unserviceable. 

The data communications channel may be treated just 
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Protocols 



Asynchronous Protocol 

This term actually refers to Two different levels of communica- 
tions; the b 1 1- level protocols, which are standardized, and the 
high-level handshaking protocols, which are not. 

As shown in Fig. 1 , each character consists of seven to twelve 
bits of binary data, The first is called the start bit, and is a logical 
zero, while the last 1 . 1 Vz or 2 bits are caJled the stop bit(s) and are 
logical ones, Between these are five to eight data bits and an 
optional parity bit. The HP Model 98628 A card is able to handle 
We forms of the parity bit: none, always zero, always one r even or 
odd. The last two options adjust the parity bit to produce a six-lo- 
nine-bit word thai contains an even or odd number of ones, 

There are several asynchronous handshaking protocols. Two of 
these are hall duplex and full duplex These protocols deal with 
the type of modem connection used to communicate between 
computers Half duplex allows only one computer to transmit at a 
time with many different conventions used to indicate when one 
computer is finished transmitting and the other may take its turn 
Full duplex allows both computers to transmit and receive at any 
time When using this kind ol connection, there are several pro- 
tocols by which a receiving computer may indicate to a transmitter 
that it is in danger of overrunning its buffers. Two of these are 
enqui re/ acknowledge {enq.ack} and start/stop (xqn xoff), The first 
is widely used by HP products, while the latter is popular among a 
number of other computers. 

Data Link Protocol 

The asynchronous multipoint protocol was first introduced as a 
means of connecting multiple HP terminals to larger HP comput- 
ers. From this came the HP data link protocol (DSN/DL), which is 
essentially the same protocol communicated over a special two- 
wire connection This cable allows communication distances of 
up to 4 km. Line control is determined through polling performed 
by the master computer. This link was used first as a means of 
connecting HP 3075A Desktop Data Capture Terminals and 
desktop computers to HP 1000 or HP 3O00 Computers. 

The characters of the DSN/DL protocol are asynchronous, with 
one start, one stop and eight data bits per character, The data is 
formed into blocks and a redundancy check is performed on each 
block to assure data integrity. If any data character is not com- 
municated properly an automatic mechanism provides retrans- 
mission o! the block of data. The controlling computer provides 
independent servicing of each terminal on the line to ensure that 
two terminals do not attempt to contuse each other's data. 
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Fig, 1 . An asynchronous character binary data stream 



like any other I/O channel. In the outbound direction, con- 
trol information is placed in the buffer with BASIC state- 
ments such as CONTROL and OUTPUT END, Outbound 
characters are placed in the buffer by OUTPUT. PRINT, and 
other statements that produce output for a printing device. 
In the inbound direction, control information is placed in 



the buffer according to decisions made by the card. The card 
allows individual selection of several conditions such as 
end-of-line received, prompt received, end-of-block> and 
parity errors. From this information, the BASIC program 
can precisely determine the location of these conditions 
relative to the data. The control information terminates an 
ENTER statement when it is reached, and the information 
associated with it may be read via two STATUS registers. 

Because of this mixed control and data buffering, several 
blocks of data can be buffered in both directions, allowing 
the user's program more time to do useful work. 

The linkage between the user program and the interface 
card is provided by some firmware, called the drivers, in the 
98 26 A and 9836A operating systems. The drivers are de- 
signed not only to make the card independent of the main- 
frame, but also to provide a common linkage mechanism for 
the 98628A and future data communications cards. The 
drivers are very simple, acting mainly as a means of com- 
municating I he users intentions to the card. The card Its©] I 
makes many decisions about the meaning of the user's 
statements. The fin wis are integrated Into the I structure, 
which allows ENTER and OUTPUT formatting as with other 
I/O cards. 

Data Communications Interface 

The 98628 A has a versatile electrical interface for connec- 
tion to a wide variety of devices. Four cables and three elec- 
trical converters (pods) provide several interface options; 

• RS-232-C DTE [male) cable 

■ RS-232-C DCE [female) cable 
RS-449/423 DTE (malej cable 

■ RS-449/422 DTE (male) cable 

■ 13264A Data Link Adapter 

■ 13265A 300-bit-per-second Modulator/Demodulator 
(modem) 

■ 13 266 A Current Loop Converter. 

The card contains drivers and receivers compatible with 
the Electronic Industries Association [EIA] KS-232-C, RS- 
449,423 and RS-449/422 standards. One set of electrical 
drivers implements the RS-232-C and RS-449/423 stan- 
dards. A separate set of drivers implements RS-449 422, To 
implement a given standard, the cable uses the appropriate 
pins on the 50-pin card connector. 

The pods change the RS-232-C electrical signals from the 
card to the proper levels for connection to other types of 
devices. Each pod consists of a box containing active cir- 
cuitry built into the cable. Power is supplied by the main- 
frame via the 50-pin connector. The 13264A Data Link 
Adapter converts the signals to the electrically isolated 
multidrop HP Data Link levels. The 13265A is a 300-bit/s 
modem for direct connection to North American telephone 
lines, supporting automatic or manual dialing to establish a 
connection to a remote computer, Finally, the 13266A Cur- 
rent Loop Converter is used to connect to older current-loop 
devices. 

Firmware 

The 9B628A firmware services two different communica- 
tions protocols: asynchronous and data link (DSN -DL]. The 
first is used for communication with almost any type of 
computer, often over telephone lines. The second is an HP 
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Electrical Standards 



For data communications, early electronic computers bor- 
rowed the current-loop signaling technsque from tetegrapft and 
teletypewriter applications Ttvs technfque uses ertner the ab- 
sence and presence of an electrical current or »ts direction to 
signal a logical zero or one Because tetetype writers 
stringent interfacing requirements, a current-loop standard has 
never been developed The driving voltage, typically between 6 
and 140 volts, determines the maximum cable length 

In the early 1960s, the Electronic industries Association (EtA), 
responding to the need lor standardized interfaces between 
computers, terminals and modems, developed the RS-232-C 
standard. R5-232-C defines theelectncai and functional charac- 
teristics of the interface between the devices and uses voltages to 
signify logic levels The data lines use negative-true logic — a 
posriive voltage between 5V and 25V represents a logical zero 
and a negative voltage between -5V and -25V represents a 
logical one. The control lines use post! ive-t rue logic— a positive 
voltage signifies an on condition and a negative voltage repre- 
sents off A 25-pin connector has become the RS-232-Cde facto 
mechanical standard RS-232-C specifies a maximum cable 
length of 15.24 metres and data transfer rates up to 20,000 bits, s 

With the need for longer cable lengths and higher data rates, 
the EIA defrned the RS-449, RS-423and RS-422 standards in the 
mid-1970s RS-449 defines the operation of 27 data, [iming and 
controllings. The basic Junctional characteristics of RS-232-C are 
retained: however, ten new circuits are defined, three old circuits 
are deleted and some changes are made to the functional defini- 
tion of some others. RS-449 specifies a 37-pin connector for mam 
channel circuits and an optional 9-pm connector for secondary 
channel lines. 

To provide an evolutionary growth path to the new standards, 
RS-423 was designed to be subset -compatible with RS-232-C 
Voltages in the positive and negative 4V-to-6V regions indicate 
logic and data levels with the same polarity as RS-232-C. Note the 
overlap between RS-232-C and RS-423 in the 5V-10-6V region 
RS-423 achieves data rates up to 1 00.000 bits/s and longer cable 
lengths using a combination ol lower voltage swings and slower 
transition rates between levels to reduce crosstalk between lines 

RS-422 defines a balanced interface circuit using the polarity ol 
the voltage between a pair of conductors to indicate a logic level 
Balanced circuits provide greater noise immunity to permit long- 
distance communication at speeds up to ten million bits>s 
RS-422 devices cannot interface directly to RS-232-C devices. 



protocol used by HP computers, data capture terminals, 
regular terminals, and now desktop computers. 

The 9H628A card firm ware is designed so that it is easy to 
use. For example, although there are two distinct data 
communications protocols that this card understands, it \b 
possible to select between them either with a hardware 
switch or by software commands from the user's program. 
There are seven other protocol default switches that can be 
used to load initial option values inlo the card. However, all 
options can be overridden by user commands. 

The eight protocol default switches on the card individu- 
ally select therumrnimh Yiiiurih protocol, common data rate, 
and modem control protocol. For asynchronous operation 
the user also may select from four common combinations of 
hi Is per character and parity. DSN/DL operation allows 
selection between eighl different device addresses. 



The firmware on the 98628 A card was written to handle 
the asynchronous and DSN 1 DL communications protocols 
completely. First, the card controls the modem lines that 
communicate with the attached hardware modem or pod. 
Second, the card handles the software, or character, pro- 
tocol to prevent buffer overruns. 

In the asynchronous mode this software protocol checks 
for handshake characters, -end-of-line sequences, and 
prompts. All of these characters may be changed or disabled 
by the user to suit specific applications. It is useful for the 
card to detect these characters because the work required by 
the mainframe is reduced and buffer overruns are pre- 
vented. For example, the card can search for carriage- 
ret urn /line- feed combinations and logically split the data at 
such points to facilitate data entry by the mainframe. 

The DSN/DL protocol is considerably more complicated, 
with blocking, error checking, and timeouts. The firmware 
for this protocol is designed as a state machine. With this 
programming concept, the reception or transmission of 
each protocol character results in a change of the card 
firmware's state, This design promotes structured, modular 
code and a more logical servicing of the DSN/DL protocol. 

The DSN/DL protocol features excellent error detection 
and recovery, mainly because a cyclic redundancy check 
(CRC) is transmitted and checked with every block of data, 
If the receiver's calculations do not agree with the transmit- 
ted CRC, the sender is asked to repeat the block of data. 
Other redundancies are also built into the protocol. For 
example, w r hen the controlling computer asks for data from 
a slave computer it issues a polling sequence containing 
two addressing characters, which are both repeated to avoid 
confusion caused by spurious line errors. 

Since the card attempts to handle both the hardware and 
software protocols completely, there are few cases in which 
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action other than the normal movement of data is required 
of the user's program. However, for those exceptional cases, 
additional CONTROL and STATUS registers are provided, 
along with interrupt mechanisms , to allow a program to 
control the card's operation. 

To facilitate friendliness and comply with legal require- 
ments for switched public telephone circuits, several time- 
outs have been implemented to catch such conditions as: 
i Not establishing a connection (caused by a misdialed 

number or busy circuits) 
s Losing a connection (the remote computer hangs up h 
there is a break in the circuit) 

Half-duplex transmission lockup (incompatible or con- 
tused half-duplex protocol) 



* Lack of data activity on the line (loss of connection or 

computer down). 
Each of these timeouts may be individually disabled or set 
to a new value by the user. 

Setf-Test 

In a typical data communications system, a number of 
devices from various manufacturers are connected to- 
gether* If the system does not operate properly, being able to 
test each of the individual blocks is important to isolating 
the problem. The 9B628A has self-test programs to respond 
to this need. At puwer-up. the card's firmware runs a test 
and signals any failure to the user. A connector for a more 
thorough hardware and cable test is also available. 




PRODUCT INFORMATION 
HP Models 9826 A and 9636 A 
Computer Systems 



MANUFACTURING DIVISION: 

1 Desktop Computer Oiu.$'on 
3400 E Harnnony Road 
Fort Collins, Colorado 80525 US A 
TECHNICAL DATA: HP Publications 59S3- 
4576 L9826A). 5953-4569 {9836AI. 5953^ 
4581 (BASIC). 5953-4594 (HPL>, ar>d 59 53^ 
4588 i Pascal f. 
PRtCE IN U.S.A.: 9B26A Computer System Option 01 1 (ROM BASIC). $8950-, 
Option 014 (ROM HPU S&95C: Option 715 (RAM Pascal), $12,750. 
9336A Computer System: Option 011 (ROM BASIC], $11 950. Opbon 014 (ROM 

HPL). S n. 950: Option 715 (RAM Pascal), £1 5.750, 
96201 A Add-On Language fir* &026A'3B38A: Option 01 1 {ROM BASIC), 
£1200; Option 014 (ROM HPL). S1000: Option 715 (RAM Pascal), S2000 




HP Model 2670 Series Printers 

MANUFACTURING DIVISION 

Vancouver Division 

2400 N.E. 651 h Avenue 

Vancouver, Washington 98661 U.S.A. 

TECHNICAL DATA; HP Pubti cation 5953-6260 

PRICE IN U.S.A.: 

2671 A Printer, Si 195. 

2671 G Graphics Printer. &1495. 

26 73 A Intelligent Graphics Printer, $2i9S. 
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